在"CodePad"(在线C++编译器)中执行链表操作时核心转储
Core dumped while performing linked list operation in "CodePad" (which is an online C++ compiler)
最近在练习一些链表编码题。我刚开始使用 unordered_set。问题是,"Write code to remove duplicates from an unsorted linked list"。为此,我使用了 unordered_set。但是当我尝试初始化链表时遇到了 "coredump" 的问题。
当我注释掉populateList的最后3行时显示数组。每当我尝试访问 populateList 中的 head 时,它都会显示核心转储。
这是我写的全部代码。我已经在codepad网站上写了这个。
#include <iostream>
#include<vector>
#include<string.h>
#include<math.h>
#include<sstream>
#include<string>
#include<stdio.h>
#include<algorithm>
#include<unordered_set>
using namespace std;
struct Node
{
int data;
Node *next;
};
Node *head=NULL;
void populateList(Node *head)
{
int arr[]={7,1,2,3,4,5,4,3,5,7,3,9,3,7,3,6,2,5,7,4};
cout<<"\n\n";
int n=sizeof(arr)/sizeof(int);
for(int i=0;i<n;i++)
{
cout<<arr[i]<<" ";
}
Node *ptr=head;
如果我注释掉下面for循环中的内容,一切都会顺利进行。
for(int i=0;i<n;i++)
{
ptr->data=arr[i];
ptr->next=NULL;
ptr=ptr->next;
}
}
int main()
{
Node *ptr=head, *prev=head;
populateList(head);
unordered_set<int> A;
while(ptr!=NULL)
{
cout<<ptr->data<<" ";
}
while(ptr!=NULL)
{
if(A.find(ptr->data)==A.end())
{
A.insert(ptr->data);
}
else
{
prev->next=ptr->next;
delete ptr;
ptr=prev->next;
}
prev=ptr;
ptr=ptr->next;
}
ptr=head;
cout<<"\n\n";
while(ptr!=NULL)
{
cout<<ptr->data<<" ";
}
return 0;
}
问题是在您的 for 循环中,您将 next 设置为 NULL,然后尝试在下一次迭代时取消引用它
for(int i=0;i<n;i++)
{
ptr->data=arr[i];
ptr->next=NULL; // now ptr->next is NULL
ptr=ptr->next; // ptr = ptr->next = NULL;
}
如果你展开这个
int i = 0;
ptr->data=arr[0];
ptr->next=NULL;
ptr=ptr->next; // ptr = ptr->next = NULL;
i++;
// because we set ptr to NULL this is dereferencing the NULL pointer
ptr->data=array[1];
...
最近在练习一些链表编码题。我刚开始使用 unordered_set。问题是,"Write code to remove duplicates from an unsorted linked list"。为此,我使用了 unordered_set。但是当我尝试初始化链表时遇到了 "coredump" 的问题。
当我注释掉populateList的最后3行时显示数组。每当我尝试访问 populateList 中的 head 时,它都会显示核心转储。
这是我写的全部代码。我已经在codepad网站上写了这个。
#include <iostream>
#include<vector>
#include<string.h>
#include<math.h>
#include<sstream>
#include<string>
#include<stdio.h>
#include<algorithm>
#include<unordered_set>
using namespace std;
struct Node
{
int data;
Node *next;
};
Node *head=NULL;
void populateList(Node *head)
{
int arr[]={7,1,2,3,4,5,4,3,5,7,3,9,3,7,3,6,2,5,7,4};
cout<<"\n\n";
int n=sizeof(arr)/sizeof(int);
for(int i=0;i<n;i++)
{
cout<<arr[i]<<" ";
}
Node *ptr=head;
如果我注释掉下面for循环中的内容,一切都会顺利进行。
for(int i=0;i<n;i++)
{
ptr->data=arr[i];
ptr->next=NULL;
ptr=ptr->next;
}
}
int main()
{
Node *ptr=head, *prev=head;
populateList(head);
unordered_set<int> A;
while(ptr!=NULL)
{
cout<<ptr->data<<" ";
}
while(ptr!=NULL)
{
if(A.find(ptr->data)==A.end())
{
A.insert(ptr->data);
}
else
{
prev->next=ptr->next;
delete ptr;
ptr=prev->next;
}
prev=ptr;
ptr=ptr->next;
}
ptr=head;
cout<<"\n\n";
while(ptr!=NULL)
{
cout<<ptr->data<<" ";
}
return 0;
}
问题是在您的 for 循环中,您将 next 设置为 NULL,然后尝试在下一次迭代时取消引用它
for(int i=0;i<n;i++)
{
ptr->data=arr[i];
ptr->next=NULL; // now ptr->next is NULL
ptr=ptr->next; // ptr = ptr->next = NULL;
}
如果你展开这个
int i = 0;
ptr->data=arr[0];
ptr->next=NULL;
ptr=ptr->next; // ptr = ptr->next = NULL;
i++;
// because we set ptr to NULL this is dereferencing the NULL pointer
ptr->data=array[1];
...