庞大资源库的计算机教程网站!
设为首页
加入收藏
总编信箱
投稿或申请专栏请先 [登 陆]
首页 操作系统 程序设计 图形图像 媒体动画 机械电子 WEB开发 数 据 库 办公系列 路由技术 网络原理 网络应用
认证考试 安全技术
首页>操作系统>Linux>编程开发>正文
资料搜索
Google搜索
Google
返回上级列表

推荐文章

快速保存网页中所有图片的方法
Windows中让光驱巧妙“隐身”技
防范非法用户入侵Win 2000/XP系
两款比较典型的ASP木马防范方法
有关表格边框的css语法整理
Windows XP中可以被禁用的服务
SQL Server导出导入数据方法
Javascript所有对象的属性的获
网页(HTML)中的特殊字符
与篮球共舞,尽显模式本色
QQ病毒的手工清除方法
Photoshop为极品美女打造性感睫
天衣无缝:IIS与PHP水火也相容
SQL Server存储过程编写和优化

基于模板类的链表

 作者:本站收集   日期:2005-4-13
字号选择〖 〗/ 双击滚屏 单击停止   
链表的使用,克服了许多基于数组表的局限性,但是传统的使用C描述的链表,使用起来也有一定的局限性,而基于C++模板类构建的链表,方便,快速,能应付很多情况。

现在,DarkSpy就将写好的基于模板类的链表帖上来,如果发现有什么错误,请随时更正我哦。^_^

// 基于模板类的链表 (C) 2001 CONEOS Software Inc.
// by DarkSpy
#include

template
class Node
{
Node *next;
protected:
T data;
public:
Node(){};
Node(Node *t, T & d); //初始化模板类

void InsertNode(Node *p, T d); //插入一个结点
void DeleteNode(Node *&p, T d); //删除一个指定结点
Node *MakeNode(Node *p, T & d); //构建链表
void Show(Node *p); //打印链表
};

template
Node ::Node(Node *t, T & d) : next(t), data(d) //初始化动作
{ }


template
void Node ::InsertNode(Node *p, T d)
{
while(p->next) p = p->next; //插入结点

next = new Node [sizeof(Node )];
p->next = new Node [sizeof(Node )]; //给新结点分配空间
p->next->data = d; //指针指向当前结点的下一结点,然后将当前结点指向新的结点
p->next->next = p->next;
next = p->next;
next->next = NULL;
}

template
void Node ::DeleteNode(Node * & p, T d) //删除结点
{
Node *temp = p; //保存表
Node *pre = NULL;
while(temp!=NULL && temp->data!=d) //遍历表寻找匹配键值
{
pre = temp;
temp = temp->next;
}

if(temp!=NULL)
{
if(pre==NULL) p = p->next; //表示如果在头结点找到键值

else pre->next = pre->next->next;//如果在以后结点找到键值
delete temp; //删除匹配结点
}
}

template
Node *Node ::MakeNode(Node *p, T & d) //构建链表
{
Node *NEW;
NEW = new Node (p, d); //给新结点分配空间
return NEW;
}

template
void Node ::Show(Node *p) //遍历结点并打印
{
while(p){
cout< data<<' ';
p = p->next;
}
}

main ()
{
Node obj, *p;
p = NULL;
for(int i=1; i<=10; i++)
p = obj.MakeNode(p, i);

obj.InsertNode(p, 32);
obj.InsertNode(p, 200);

obj.Show(p); cout<<'\n';
obj.DeleteNode(p, 10);
obj.DeleteNode(p, 32);
obj.InsertNode(p, 120);
obj.Show(p);
}

是不是很简单呢?这段代码稍稍修改就可以应用在许多方面,我们可以使用Node 来建立字典等等有用的功能。

DarkSpy 2001/04/27
上一篇:算法于效率    下一篇:如何写安全的 C 程序  
[发送给好友]  [关闭窗口]  [返回顶部]   转载请注明来源:www.it00.com   
特别声明: 本站除部分特别声明禁止转载的专稿外的其他文章可以自由转载,但请务必注明出处和原始作者。文章版权归文章原始作者所有。对于被本站转载文章的个人和网站,我们表示深深的谢意。如果本站转载的文章有版权问题请联系编辑人员,我们尽快予以更正。
责任编辑: 原点 投稿作者: 本站收集
信息来源: 网络 录入时间: 2005-4-13
关于我们 - 广告服务 - 版权申明 - 网站地图 - 联系方式 - 总编信箱 - 会员投稿