Cha11enge 2024-07-22 17:55 采纳率: 0%
浏览 5

这链表怎么这么奇怪吖

为什么head会和tail一起指向tmp啊,明明只有tail=tmp

img

  • 写回答

4条回答 默认 最新

  • 阿里嘎多学长 2024-07-22 17:58
    关注

    以下内容由AIGC及阿里嘎多学长共同生成、有用望采纳:


    问题分析

    1. 理解链表初始化错误

      • 在提供的代码中,headtail同时指向tmp的原因是因为在分配第一个节点时,headtail都被赋值为tmp。这在单链表的初始化中是正确的,因为此时只有一个节点,headtail都指向这个节点。
      tmp = new st_girl({1, "aaa", nullptr});
      head = tail = tmp;
      
      • 但是,问题出现在分配第二个节点时,代码中存在错误。注释和代码不一致,导致tail没有正确地移动到新的节点。
      tmp = new st_girl(1 6, "bbb", nullptr); // 这里注释错误,应该是{2, "bbb", nullptr}
      tail->next = tmp; // 将上一个节点的next指针指向新节点。
      tail = tmp;       // 移动tail指针,让它指向刚分配出来的新节点。
      
    2. 修正链表初始化代码

      • 确保链表的头指针head和尾指针tail正确地指向链表的开始和结束。在分配第一个节点时,headtail都指向这个节点。
      tmp = new st_girl({1, "aaa", nullptr});
      head = tmp; // 只设置head指向新分配的节点。
      tail = tmp; // 设置tail也指向新分配的节点,因为这是链表的第一个也是最后一个节点。
      
      • 在分配第二个节点时,确保tail指针正确地移动到新的节点。
      tmp = new st_girl({2, "bbb", nullptr});
      tail->next = tmp; // 将上一个节点的next指针指向新节点。
      tail = tmp;       // 移动tail指针,让它指向刚分配出来的新节点。
      
    3. 正确分配和链接节点

      • 在分配第三个节点时,确保每个新节点被正确地添加到链表中,并且tail指针正确地指向链表的最后一个节点。
      tmp = new st_girl({3, "ccc", nullptr});
      tail->next = tmp; // 将上一个节点的next指针指向新节点。
      tail = tmp;       // 移动tail指针,让它指向刚分配出来的新节点。
      

    修正后的完整代码

    #include <iostream>
    #include <string>
    
    using namespace std;
    
    struct st_girl {
        int no;
        string name;
        struct st_girl* next;
    
        st_girl(int no, string name, struct st_girl* next) : no(no), name(name), next(next) {}
    };
    
    int main() {
        st_girl* head = nullptr, * tail = nullptr, * tmp = nullptr;
    
        // 分配第一个节点。
        tmp = new st_girl(1, "aaa", nullptr);
        head = tmp; // 只设置head指向新分配的节点。
        tail = tmp; // 设置tail也指向新分配的节点,因为这是链表的第一个也是最后一个节点。
    
        // 分配第二个节点。
        tmp = new st_girl(2, "bbb", nullptr);
        tail->next = tmp; // 将上一个节点的next指针指向新节点。
        tail = tmp;       // 移动tail指针,让它指向刚分配出来的新节点。
    
        // 分配第三个节点。
        tmp = new st_girl(3, "ccc", nullptr);
        tail->next = tmp; // 将上一个节点的next指针指向新节点。
        tail = tmp;       // 移动tail指针,让它指向刚分配出来的新节点。
    
        // 遍历链表。
        for (st_girl* current = head; current != nullptr; current = current->next) {
            cout << "No: " << current->no << ", Name: " << current->name << endl;
        }
    
        return 0;
    }
    

    这段代码首先初始化链表,然后逐个添加节点,并通过遍历链表来验证链表的正确性。

    评论 编辑记录

报告相同问题?

问题事件

  • 创建了问题 7月22日

悬赏问题

  • ¥15 如何在vue.config.js中读取到public文件夹下window.APP_CONFIG.API_BASE_URL的值
  • ¥50 浦育平台scratch图形化编程
  • ¥20 求这个的原理图 只要原理图
  • ¥15 vue2项目中,如何配置环境,可以在打完包之后修改请求的服务器地址
  • ¥20 微信的店铺小程序如何修改背景图
  • ¥15 UE5.1局部变量对蓝图不可见
  • ¥15 一共有五道问题关于整数幂的运算还有房间号码 还有网络密码的解答?(语言-python)
  • ¥20 sentry如何捕获上传Android ndk 崩溃
  • ¥15 在做logistic回归模型限制性立方条图时候,不能出完整图的困难
  • ¥15 G0系列单片机HAL库中景园gc9307液晶驱动芯片无法使用硬件SPI+DMA驱动,如何解决?