通用单向链表,使用模板(template)。
[@more@]#include
using namespace std;
template
{
public:
List();
void Add(T&);
void Remove(T&);
T* Find(T&);
void PrintList();
~ List();
protected:
struct Node{
Node* pNext;
T* pT;
};
Node *pFirst;
};
template
{
pFirst=0;
}
template
{
Node* temp=new Node;
temp->pT=&t;
temp->pNext=pFirst;
pFirst=temp;
}
template
{
Node* q=0;
if(*(pFirst->pT)==t)
{
q=pFirst;
pFirst=pFirst->pNext;
}else
{
for(Node* p=pFirst;p->pNext;p=p->pNext)
{
if(*(p->pNext->pT)==t)
{
q=p->pNext;
p->pNext=q->next;
break;
}
}
}
if(q)
{
delete q->pT;
delete q;
}
}
template
{
for(Node* p=pFirst;p;p=p->pNext)
{
if(*(p->pT)==t)
{
return p->pT;
}
else
{
return 0;
}
}
}
template
{
for(Node* p=pFirst;p;p=p->pNext)
{
cout<<*(p->pT)<<" ";
}
cout<
template
{
Node* p;
while(p=pFirst)
{
pFirst=pFirst->pNext;
delete p->pT;
delete p;
}
}
int main()
{
List
for(int i=0;i<10;i++)
{
intlist.Add(* new int(i));
}
intlist.PrintList();
return 0;
}