HEIMIIY 2018-07-02 11:57 采纳率: 0%
浏览 1925
已采纳

单链表删除 清空链表过程注释

void List::ClearList(){//清空链表
Node *currentNode=m_pList->next;
while(currentNode!=NULL)/
{
Node *temp=currentNode->next;
delete currentNode;
currentNode=temp;
}
m_pList->next=NULL;

        m_pList->data=0;//这个的含义是表头数据为0吗
  • 写回答

2条回答 默认 最新

  • threenewbee 2018-07-02 12:46
    关注

    你这个代码的实现的方式是
    从链表的头开始,往后,temp保存的是待删除的节点后一个节点,而currentNode是待删除的节点,每次释放currentNode,而让temp成为新的currentNode(让temp的下一个节点成为temp)
    最后是清理头节点(让它的数据域data=0,指针域next\null)

    这个代码其实有两个问题,第一,头节点也是普通节点,那么头节点的 data = 0,说明它是空的么?还是只有一个节点,并且这个节点的数据是0呢?没法区别。解决办法是,引入一个没有数据域的头指针,比如叫header。
    第二个问题,一旦循环删除失败,那么完蛋了,从失败开始往后的内存全部泄露了。解决办法是从后往前删除。

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

悬赏问题

  • ¥15 孟德尔随机化结果不一致
  • ¥15 apm2.8飞控罗盘bad health,加速度计校准失败
  • ¥15 求解O-S方程的特征值问题给出边界层布拉休斯平行流的中性曲线
  • ¥15 谁有desed数据集呀
  • ¥20 手写数字识别运行c仿真时,程序报错错误代码sim211-100
  • ¥15 关于#hadoop#的问题
  • ¥15 (标签-Python|关键词-socket)
  • ¥15 keil里为什么main.c定义的函数在it.c调用不了
  • ¥50 切换TabTip键盘的输入法
  • ¥15 可否在不同线程中调用封装数据库操作的类