我还是C ++的新手。我的append()函数遇到了问题。我不允许更改此作业的参数。我认为问题是我误解了过去的论点。我相信它是头节点指针的地址?但是,当我编译并运行驱动程序时,我得到了分段错误。
#include <iostream>
struct node {
int data;
node* next;
};
node* init_node(int data);
std::string report(node* head);
void append_data(node** head, int data);
void append(node** head, node* new_node);
#include "linkList.h"
using namespace std;
node* init_node(int data) {
node* newNode = new node;
newNode->data = data;
newNode->next = NULL;
return newNode;
}
string report(node* root) {
string nodeData;
if(root->next != NULL){
nodeData = to_string(root->data)+" ";
while (root->next != NULL) {
nodeData = nodeData+(to_string(root->data)+" ");
root = root->next;
}
return nodeData;
}else{
return "";
}
}
void append_data(node** head, int data) {
node* newNode = init_node(data);
append(head, newNode);
}
//function causing problem
void append(node** head, node* new_node) {
node* tmp = *head;
while (tmp->next != NULL) {
tmp = newHead->next;
}
tmp->next = new_node;
}
#include "linkList.h"
#inlcude "linkList.cpp"
int main(){
cout << "Testing Linked List" << endl;
node* empty_list = NULL;
cout << "Empty List Contents: " << report(empty_list) << endl;
append_data(&empty_list, 16); //causing error here
cout << "Empty List Contents after appending 16: ";
}
如果有语法错误,我道歉。我试图复制并粘贴只有必要的东西,因为还有更多这个。
答案 0 :(得分:2)
正如我上面所说,如果append
为空,tmp
并不好。当您将新节点附加到列表时,附加到空列表是一种特殊情况:
void append(node** head, node* new_node){
node* tmp = *head;
if(tmp==NULL) {
*head = new_node;
return;
}
while (tmp->next != NULL) {
tmp = tmp->next;
}
tmp->next = new_node;
}
答案 1 :(得分:0)
在驱动程序中:
node* empty_list = NULL;
但在append()中,您使用tmp->next which
是&#34; empty_list->next
&#34;,这会导致段错误