鱼C论坛

 找回密码
 立即注册
查看: 581|回复: 1

[已解决]单链表尾插法

[复制链接]
发表于 2023-11-30 09:59:08 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

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

x
  1. if (*library != NULL)
  2.         {
  3.                 tail->next = book;
  4.                 book->next = NULL;
  5.         }
  6.         else
  7.         {
  8.                 *library = book;
  9.                 book->next = NULL;
  10.         }
  11.    
  12.         tail = book;
复制代码


这一段什么意思,为什么不能直接 tail->next = NULL
最佳答案
2023-11-30 09:59:20
这段代码是在实现单链表的尾插法插入节点。其中的逻辑是判断链表是否为空,如果不为空,则将新节点(book)链接到链表的尾部;如果链表为空,则将新节点作为链表的头节点(*library)。

tail->next = book 是将原链表的尾节点(tail)的next指针指向新节点(book),这样就将新节点插入到了链表的尾部。而 tail = book 是将尾节点指针更新为新节点,以便下一次插入操作时可以正确找到链表的尾部。

至于为什么不能直接 tail->next = NULL,是因为这样会断开原链表的连接,导致链表丢失。在尾插法中,我们需要保持链表的完整性,所以需要将新节点与原链表的尾节点进行连接。

以上回复来自 -- ChatGPT(FishC官方接口),如未能正确解答您的问题,请继续追问。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2023-11-30 09:59:20 | 显示全部楼层    本楼为最佳答案   
这段代码是在实现单链表的尾插法插入节点。其中的逻辑是判断链表是否为空,如果不为空,则将新节点(book)链接到链表的尾部;如果链表为空,则将新节点作为链表的头节点(*library)。

tail->next = book 是将原链表的尾节点(tail)的next指针指向新节点(book),这样就将新节点插入到了链表的尾部。而 tail = book 是将尾节点指针更新为新节点,以便下一次插入操作时可以正确找到链表的尾部。

至于为什么不能直接 tail->next = NULL,是因为这样会断开原链表的连接,导致链表丢失。在尾插法中,我们需要保持链表的完整性,所以需要将新节点与原链表的尾节点进行连接。

以上回复来自 -- ChatGPT(FishC官方接口),如未能正确解答您的问题,请继续追问。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2024-5-11 21:55

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表