双链表实现

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

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

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

 

 

下面贴代码


      #include <stdio.h>
      #include <stdlib.h>
      #include <string.h>
      typedef struct node{
      int key;//数据
      struct node * prev;//前驱
      struct node * next;//后继
      }Node;
  
 

初始化(带头) 


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

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


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

打印


      void printList(Node * list)//打印
      {
       Node * temp = list->next;头节点下一个开始
      while(temp != NULL)
       {
      printf("%d ",temp->key);
       temp = temp->next;
       }
      printf("\n");
      }
  
 

删除指定结点


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

配合一下删除:


      void deleteKey(int key,Node * list)
      {
      delete(find(key,list));
      }
  
 

头插:


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

按下标插入

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


      void insert(int key,Node * list,int index)
      {
       Node * head=list;//最后指到要插位置的前一个即可
       Node * newNode = (Node *)malloc(sizeof(Node));//初始化
       newNode->key = key;
      while(index--)
       head = head->next;
       newNode->next = head->next;//修改指针
       newNode->prev = head;
       head->next = newNode;
      }
  
 

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

 

然后简单测试


      int main()
      {
       Node * list = NULL;
       init(list);
       insertHead(1,list);
       insertHead(2,list);
       insertHead(3,list);
       printList(list);
       deleteKey(2,list);
       printList(list);
       insert(10,list,0);
       printList(list);
      }
  
 

 

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

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

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

评论(0

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

全部回复

上滑加载中

设置昵称

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

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

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