微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

链表创建和显示

如何解决链表创建和显示

我的链表代码未打印最后一个节点,您能在哪里弄错吗? 我试了做,但没有用 我不想为此分离头节点,请不要告诉我更改整个代码 我如何释放整个代码分配的内存 最后我如何使用递归进行显示

WorkerThread *workerThread = new WorkerThread(this);

解决方法

当while循环中的条件失败时,您仍未检查所处的最后一个节点。在上次迭代结束时取消了对它的引用,但从未在其中打印数据。一种快速的解决方法是在循环退出后仅打印当前节点的数据:

    while(p->next != NULL)
    {
       printf("\n data: %d",p->data);
       p=p->next;
    }
    printf("\n data: %d",p->data);

这还将解决您的评论中提到的问题。当然,您仍然需要在执行此操作之前确保列表不为空。

,

考虑单节点链接列表的情况。 Head-> next将评估为NULL。并且Head的值将不会显示。为了解决此问题,请向上移动printf语句。

编辑:您还必须确保HEAD不为空,否则,如果进行更改,您的代码仍将失败

void display(node* head)
{
    node* p= head;

    while(p->next != NULL)
    {
    printf("\n data: %d",p->data);
    p=p->next;
    }

}
,

问题在于您的情况,您需要将while(p->next != NULL)更改为while(p != NULL)。 这样做的原因是因为您的指针位于最后一个元素上,但是您正在检查其下一个元素。 另外,将int create(int n)更改为node * create(int n)。您正在返回指针,而不是int参数。

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。