单链表,为什么列表为空(head == NULL)?

时间:2015-06-04 09:37:49

标签: c++ list c++11 data-structures singly-linked-list

我创建了一个单独的链接列表:

#include <iostream>

using namespace std;

struct Node{
    int data;
    Node *next;
};

bool isEmpty(Node *head){
    if (head == NULL){
        return true;
    }
    else{
        return false;
    }
}

void append(Node *head, Node *last, int data){
    Node *newNode = new Node;
    newNode->data = data;
    newNode->next = NULL;
    if (isEmpty(head)){
        head = newNode;
        last= newNode;
    }
    else{
        last->next = newNode;
        last= newNode;
    }

}

void printList(Node *current){
    if (isEmpty(current)){
        cout << "List is empty." << endl;
    }
    else{
        int i = 1;
        while (current != NULL){
            cout << i << ". Node: " << endl;
            cout << current->data << endl;
            current = current->next;
            i++;
        }
    }
}

void main(){
    Node *head = NULL;
    Node *last = NULL;
    append(head, last, 53);
    append(head, last, 5512);
    append(head, last, 13);
    append(head, last, 522);
    append(head, last, 55);
    printList(head);
}

编译时,输出为:

  

列表为空。

但我不知道为什么。 “head”获取一个地址,因此“head”不应为NULL。但显然它是NULL。 我不知道如何解决这个问题。

4 个答案:

答案 0 :(得分:4)

你必须记住函数的参数默认是通过值传递的,这意味着参数值是复制的,并且该函数仅适用于副本,而不适用于原始函数。

现在使用append函数,当您传递head参数时,指针被复制到参数中,并且对函数内的head所做的任何更改都只对该副本进行

要使其正常工作,您需要传递您通过引用更改的参数,例如

void append(Node *&head, Node *&last, int data)

现在headlast是对原始指针变量的引用,对变量的更改是对原始变量的。

答案 1 :(得分:1)

参数headlast按值传递,因此函数append内的变量与外部变量无关,它们是独立的。

您需要通过引用或指针指针传递它,例如:

void append(Node *&head, Node *&last, int data) {

答案 2 :(得分:1)

在函数中:append(Node *head, Node *tail, int data)

您应该通过引用传递headtail。在您分配head = newNode的方法中,它会被分配到head的本地副本,而不是您传递的head

答案 3 :(得分:0)

传递头部和最后一个变量的地址,并且它会起作用。

append(&head, &last, 53);

和附加功能的变化如下

void append(Node **head, Node **last, int data)