quiettttt 2022-11-01 17:28 采纳率: 97.9%
浏览 22
已结题

这是段测试链表的代码,为什么每次输出都有一个垃圾数?是因为new没有释放吗?

using namespace std;
#include <iostream>
typedef struct Node{
    int data;
    Node *next;
};

Node *createList(int num)
{
    Node *Head = new Node;
//    Head = nullptr;
    Head ->next = nullptr;
    Node *prev = Head;

    for (int i = 0; i < num; ++i)
    {
        cout << "Enter "<< i+1 << endl;
        Node *temp = new Node;
        cin >> temp->data;
        prev ->next = temp;
        prev = temp;
        temp ->next = nullptr;
    }
    return Head;
}
void display(Node * head)
{
    cout << "Now:";
    while(head != nullptr)
    {
        cout <<head->data << " ";
        head = head ->next;
    }
}

int main(void)
{
    int num;
    cout << "Enter How?" ;
    cin >> num;
    cout << endl;
    Node *head;
    head = createList(num);
    display(head);

    return 0;
}

这是段测试链表的代码,为什么每次输出都有一个垃圾数?是因为new没有释放吗?

img

  • 写回答

2条回答 默认 最新

  • 快乐鹦鹉 2022-11-01 17:31
    关注

    因为你这是有固定头结点的链表,所以输出时,头结点不要输出。

    void display(Node * head)
    {
        cout << "Now:";
        head = head->next;
        while(head != nullptr)
        {
            cout <<head->data << " ";
            head = head ->next;
        }
    
    
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

问题事件

  • 系统已结题 11月9日
  • 已采纳回答 11月1日
  • 创建了问题 11月1日

悬赏问题

  • ¥100 set_link_state
  • ¥15 虚幻5 UE美术毛发渲染
  • ¥15 CVRP 图论 物流运输优化
  • ¥15 Tableau online 嵌入ppt失败
  • ¥100 支付宝网页转账系统不识别账号
  • ¥15 基于单片机的靶位控制系统
  • ¥15 真我手机蓝牙传输进度消息被关闭了,怎么打开?(关键词-消息通知)
  • ¥15 装 pytorch 的时候出了好多问题,遇到这种情况怎么处理?
  • ¥20 IOS游览器某宝手机网页版自动立即购买JavaScript脚本
  • ¥15 手机接入宽带网线,如何释放宽带全部速度