1.2.1-2部分数据结构的阐明02_链表

打印 上一主题 下一主题

主题 1017|帖子 1017|积分 3051

马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。

您需要 登录 才可以下载或查看,没有账号?立即注册

x
(1)链表数据结构:

概念:

将列表中相互毗连的节点不连续的存储在内存中。与数据不同,我们无法再恒定时间内访问任何元组,如果遍历所有则泯灭时间与元素总数n成正比。插入和删除1个元素的时间复杂度都是O(n)。链表中每个块成为一个节点,每个节点有两个字段,一个存储数据,另一个存储下一个节点的地点(链接字段)。


特点:

(1) 每个节点由2个字段构成,1个存储数据,另1个存储下一个节点的地点。
(2) 下一个节点的名称与上一个节点的link同等。
(3)存整数型的数组(array)占4字节,而链表因存储地点故所需8字节。对于大量数据,链表比数组所需的内存要小,缘故原由是数组要预留很多空的内存空间。

C语言中表述




(1)逻辑代码——插入第1个节点

  1. typedef struct Node {
  2.     int data;        // 用于存储数据
  3.     struct Node* link;   // 指向下一个节点的指针
  4. } Node;
  5. //(1) 创建指针
  6. Node* A;  //声明指向节点的指针 A
  7. A = NULL; //最初列表为空,指针 A 不指向任何位置
  8. //(2) 插入节点。用malloc函数创建内存块,参数是内存块所需字节数
  9. Node* temp = (Node*)malloc(sizeof(Node));
  10. //说明:malloc返回void指针,该指针为我们提供分配的内存块地址
  11. //说明:我们把它保存在名为temp的变量里,最后需要类型转换(由于返回void指针)
  12. //(4) 把数据写入该节点,并调整链接。
  13. #if 0
  14. (*temp).data = 2;
  15. //说明:向 A 写入地址,以及调整新创建节点的链接字段。为此必须解引用指针(也就是刚创建的变量temp)。
  16. //说明:变量前加"*"可解引用并可以修改地址的值(也就是内容)。
  17. (*temp).link = NULL;
  18. //说明:我们这个临时变量temp指向这个节点,此时这个节点是第一个也是最后一个节点,所以链接不是是NULL
  19. #else
  20. temp->data = 2;
  21. temp->link = NULL;
  22. #endif
  23. A = temp;
  24. //说明:把新创建节点的地址写入 A
  25. //说明:temp事实用来暂时存储节点地址,一旦链接调整完成,temp就可用于其他目的
  26.    
复制代码
(2)逻辑代码——遍历后再链表最后插入第1个节点

  1. typedef struct Node {
  2.     int data;      
  3.     struct Node* link;  
  4. } Node;
  5. //(1) 创建指针
  6. Node* A;  
  7. A = NULL;
  8. //(2) 构建第1个节点,并写入数据和地址
  9. Node* temp = (Node*)malloc(sizeof(Node));
  10. temp->data = 2;
  11. temp->link = NULL;
  12. //(3)把新节点的地址写入原本为NULL的此前尾节点的link
  13. A = temp;
  14. //(4)遍历节点地址后,插入新节点
  15. Node* temp1 = A;
  16. while(temp1->link != NULL){ //用最后一个节点地址为空,作为判断
  17.      temp1 = temp1->link;
  18. }
  19. //(5)创建新节点,并在新节点内写入数据
  20. Node* newtemp = (Node*)malloc(sizeof(Node));
  21. newtemp->link = NULL;
  22. newtemp->data = 3;
  23. //(6)把新节点的地址写入原本为NULL的此前尾节点的link
  24. temp1->link = newtemp;
复制代码




截图参考来自,很好的视频

免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。
回复

使用道具 举报

0 个回复

倒序浏览

快速回复

您需要登录后才可以回帖 登录 or 立即注册

本版积分规则

没腿的鸟

论坛元老
这个人很懒什么都没写!
快速回复 返回顶部 返回列表