微风中寂寞的痛 2022-03-04 23:21 采纳率: 100%
浏览 23
已结题

C++关于链表SOS

要求是通过循环语句生成结点,创建一个单链表,保存1-30间的所有30个整数,并且输出。
😭😭输出结果1的循环是哪一步出了问题啊

img

img

源代码如下
#include
#include
using namespace std;
struct node{
int data;
struct nodenext;
};
int main()
{
struct node
q=(struct node*)malloc(sizeof(struct node));
struct node*t=q;
for(int i=1;i<=30;i++){
struct node*s=(struct node*)malloc(sizeof(struct node));
s->data=i;
t->next=s;
t=s;
}
t->next=NULL;
cout<<endl;
for(t=q->next;t;t->next){
cout<data<<" ";
}
return 0;
}

  • 写回答

3条回答 默认 最新

  • CSDN专家-link 2022-03-05 07:45
    关注

    for(t = q->next;t;t=t->next)
    ...
    最后应该是t=t->next,这样t才不断指向链表的下一个节点。
    t->next是不会改变t的值的。所以t没有改变,导致死循环了。

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

报告相同问题?

问题事件

  • 系统已结题 3月13日
  • 已采纳回答 3月5日
  • 创建了问题 3月4日

悬赏问题

  • ¥15 求Houdini使用行家,付费。价格面议。
  • ¥15 AttributeError: 'EasyDict' object has no attribute 'BACKUP_DB_INFO'
  • ¥15 前端高拍仪调用问题报错
  • ¥15 想用octave解决这个数学问题
  • ¥15 Centos新建的临时ip无法上网,如何解决?
  • ¥15 海康威视如何实现客户端软件对设备语音请求的处理。
  • ¥15 支付宝h5参数如何实现跳转
  • ¥15 MATLAB代码补全插值
  • ¥15 Typegoose 中如何使用 arrayFilters 筛选并更新深度嵌套的子文档数组信息
  • ¥15 前后端分离的学习疑问?