o(*≧▽≦)o 2021-12-22 21:41 采纳率: 100%
浏览 8
已结题

关于C语言链表的头链问题

就是这个函数

img


我想弄清楚它是在哪一步给pHead->next赋值的。编了一个类似的程序发现在执行else ptail->next=pNew;时pHead->next发生了改变,为什么?

img


以及图1//设置新的尾节点那一句,为什么要这样做?

  • 写回答

1条回答 默认 最新

  • CSDN专家-link 2021-12-22 21:44
    关注

    就是这个pTail啊
    pTail只是个节点指针命名方式而已,你不用在意这里叫Tail还是Head
    由于代码采用尾插法,所以必须定义一个节点指针,始终指向当前链表的尾节点,这里就是 pTail
    初始的pTail和pHead都指向第一次分配的pNew指针,然后pHead保持不变,通过pTail->next一直在修改尾节点的next指向下一个新建的pNew节点,再将pTail指向pNew

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论 编辑记录

报告相同问题?

问题事件

  • 系统已结题 12月30日
  • 已采纳回答 12月22日
  • 创建了问题 12月22日