首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >在"CodePad“(在线C++编译器)中执行链接列表操作时转储核心

在"CodePad“(在线C++编译器)中执行链接列表操作时转储核心
EN

Stack Overflow用户
提问于 2017-08-24 12:59:16
回答 1查看 77关注 0票数 0

最近,我一直在练习一些链接列表编码问题。我刚刚开始使用unordered_set。问题是,“编写代码从未排序的链接列表中删除重复项”。我用过unordered_set来做这个。但是当我尝试初始化链接列表时,我遇到了"coredump“的问题。

当我注释掉populateList的最后3行时,它将显示数组。当我试图访问populateList中的head时,它会显示抛出的内核。

这是我写的全部代码。我已经写在代码页网站上。

代码语言:javascript
复制
#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循环中的内容,所有内容都会顺利运行。

代码语言:javascript
复制
    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;
}
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2017-08-24 14:04:11

问题是,在for循环中,您在NULL旁边设置,然后在下次迭代时尝试取消引用它。

代码语言:javascript
复制
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;
}

如果你打开这个

代码语言:javascript
复制
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];
...
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/45862316

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档