双链表实现

举报
兔老大 发表于 2021/04/21 22:52:16 2021/04/21
【摘要】 以前写的不带头的单链表实现,当时也啥也没学,好多东西不知道,加上一心想压缩代码,减少情况,所以写得不太好。 请教了老师,首先是命名问题和代码紧凑性等的改进。还有可读性方面的改进,多写了一些注释。并且因为带头的比较好写,好操作,所以标准写法也不是很长,繁琐。     下面贴代码 #include <stdio.h>#include &l...

以前写的不带头的单链表实现,当时也啥也没学,好多东西不知道,加上一心想压缩代码,减少情况,所以写得不太好。

请教了老师,首先是命名问题和代码紧凑性等的改进。还有可读性方面的改进,多写了一些注释。并且因为带头的比较好写,好操作,所以标准写法也不是很长,繁琐。

 

 

下面贴代码


  
  1. #include <stdio.h>
  2. #include <stdlib.h>
  3. #include <string.h>
  4. typedef struct node{
  5. int key;//数据
  6. struct node * prev;//前驱
  7. struct node * next;//后继
  8. }Node;

初始化(带头) 


  
  1. Node * list;
  2. //初始化,这里·我们list不再是NULL,而是指向了一个节点
  3. //这个改进方便了很多操作,也不用借助二重指针把list和next统一表示了
  4. void init(Node * list)//初始化
  5. {
  6. list = (Node *)malloc(sizeof(Node));
  7. list->next = NULL;
  8. list->prev = NULL;
  9. }

查找(不用再判断一下空不空)


  
  1. Node * find(int key,Node * list)
  2. {
  3. Node * head = list->next;//从头节点后面开始找
  4. while(head != NULL && head->key != key)//找到或空跳出
  5. head = head->next;
  6. return head;
  7. }

打印


  
  1. void printList(Node * list)//打印
  2. {
  3. Node * temp = list->next;头节点下一个开始
  4. while(temp != NULL)
  5. {
  6. printf("%d ",temp->key);
  7. temp = temp->next;
  8. }
  9. printf("\n");
  10. }

删除指定结点


  
  1. void delete(Node * list)//删除指定结点
  2. {
  3. list->prev->next = list->next;前面后面指针改了,再free自己即可
  4. list->next->prev = list->prev;
  5. free(list);
  6. }

配合一下删除:


  
  1. void deleteKey(int key,Node * list)
  2. {
  3. delete(find(key,list));
  4. }

头插:


  
  1. void insertHead(int key,Node * list)//头插
  2. {
  3. Node * newNode = (Node *)malloc(sizeof(Node));//初始化
  4. newNode->key = key;
  5. newNode->next = list->next;//赋值后继
  6. if(list->next != NULL)//如果有后继,赋值后继的前指针为新结点
  7. list->next->prev = newNode;
  8. list->next = newNode;//改头
  9. newNode->prev = list;//赋值新结点前指针
  10. }

按下标插入

单链表都写了,我就不写长度函数和判断非法了,用的时候注意吧。


  
  1. void insert(int key,Node * list,int index)
  2. {
  3. Node * head=list;//最后指到要插位置的前一个即可
  4. Node * newNode = (Node *)malloc(sizeof(Node));//初始化
  5. newNode->key = key;
  6. while(index--)
  7. head = head->next;
  8. newNode->next = head->next;//修改指针
  9. newNode->prev = head;
  10. head->next = newNode;
  11. }

指定某值后插入不写了,和这个修改指针逻辑一样,再传一个find配合一下就行了。

 

然后简单测试


  
  1. int main()
  2. {
  3. Node * list = NULL;
  4. init(list);
  5. insertHead(1,list);
  6. insertHead(2,list);
  7. insertHead(3,list);
  8. printList(list);
  9. deleteKey(2,list);
  10. printList(list);
  11. insert(10,list,0);
  12. printList(list);
  13. }

 

文章来源: fantianzuo.blog.csdn.net,作者:兔老大RabbitMQ,版权归原作者所有,如需转载,请联系作者。

原文链接:fantianzuo.blog.csdn.net/article/details/82784343

【版权声明】本文为华为云社区用户转载文章,如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。