数据结构-头插法和尾插法
【摘要】
数据结构——八大算法总结(最详细)
头插法
void HeadCreatList(List *L) //头插法建立链表{List *s; //不用像尾插法一样生成一个终端节点。L->next = NULL;for (int i = 0; i < 10; i++) { s = (struct ...
头插法
-
void HeadCreatList(List *L) //头插法建立链表
-
{
-
List *s; //不用像尾插法一样生成一个终端节点。
-
L->next = NULL;
-
for (int i = 0; i < 10; i++) {
-
s = (struct List*) malloc(sizeof(struct List));//s指向新申请的节点
-
s->data = i;//用新节点的数据域来接受i
-
s->next = L->next; //将L指向的地址赋值给S;//头插法与尾插法的不同之处主要在此,
-
//s所指的新节点的指针域next指向L中的开始节点
-
L->next = s; //头指针的指针域next指向s节点,使得s成为开始节点。
-
}
-
}
尾插法
-
void TailCreatList(List *L) //尾插法建立链表
-
{
-
List *s, *r;//s用来指向新生成的节点。r始终指向L的终端节点。
-
r = L; //r指向了头节点,此时的头节点是终端节点。
-
for (int i = 0; i < 10; i++) {
-
s = (struct List*) malloc(sizeof(struct List));//s指向新申请的节点
-
s->data = i; //用新节点的数据域来接受i
-
r->next = s; //用r来接纳新节点
-
r = s; //r指向终端节点
-
}
-
r->next = NULL; //元素已经全部装入链表L中
-
//L的终端节点指针域为NULL,L建立完成
-
}
文章来源: hiszm.blog.csdn.net,作者:孙中明,版权归原作者所有,如需转载,请联系作者。
原文链接:hiszm.blog.csdn.net/article/details/80954203
【版权声明】本文为华为云社区用户转载文章,如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱:
cloudbbs@huaweicloud.com
- 点赞
- 收藏
- 关注作者
评论(0)