Yester07 2022-03-24 20:58 采纳率: 48.5%
浏览 43
已结题

链表出现了问题,堆栈已损坏,指针不兼容,求解决

代码:

#define _CRT_SECURE_NO_WARNINGS
#include "stdio.h"
#include "stdlib.h"
typedef struct
{
    int value;
    struct node* next;
}node;

int creatlistf(node* l, int data[], int length)
{
    node* p;
    if (l)
    {
        l->next = NULL;
        for (int i = 0; i < length; i++)
        {
            p = (node*)malloc(sizeof(node));
            p->value = data[i];
            p->next = l->next;
            l->next = p;
        }
        return 1;
    }
    return 0;
}

int creatlistr(node* l, int data[], int length)
{
    node* r, *p;
    if (l)
    {
        l->next = NULL;
        r = l;
        for (int i = 0; i < length; i++)
        {
            p = (node*)malloc(sizeof(node));
            p->value = data[i];
            printf("%d\t", p->value);
            r->next = p;
            r = p;
        }
        r->next = NULL;
        return 1;
    }
    return 0;
}

void displist(node* l)
{
    node* p;
    if (l)
    {
        p = l;
        while (p->next != NULL)
        {
            p = p->next;
            printf("%d\t", p->value);
        }
    }
}
int main()
{
    node* l;
    l = (node*)malloc(sizeof(node));
    int x[10] = { 1,2,3,4,5,6,7,8,9,10 },STATUS=0;
    STATUS = creatlistf(&l, x, 10);
    displist(&l);
    return 0;
}

具体报错如下(软件为vs),因为是xin shou,希望能点名原因和修改方法,谢谢!翻译是是l的两个堆栈已损坏。

img

谢谢!

  • 写回答

3条回答 默认 最新

  • fuill 2022-03-24 21:14
    关注

    改了三个地方,写注释里了

    #define _CRT_SECURE_NO_WARNINGS
    #include "stdio.h"
    #include "stdlib.h"
    typedef struct Node
    {
        int value;
        struct Node* next;
    }node;
     //定义的链表和节点是两个不同的结构体 ,名字不能一样
    //node是链表名,Node是节点名
    int creatlistf(node* l, int data[], int length)
    {
        node* p;
        if (l)
        {
            l->next = NULL;
            for (int i = 0; i < length; i++)
            {
                p = (node*)malloc(sizeof(node));
                p->value = data[i];
                p->next = l->next;
                l->next = p;
            }
            return 1;
        }
        return 0;
    }
     
    int creatlistr(node* l, int data[], int length)
    {
        node* r, *p;
        if (l)
        {
            l->next = NULL;
            r = l;
            for (int i = 0; i < length; i++)
            {
                p = (node*)malloc(sizeof(node));
                p->value = data[i];
                printf("%d\t", p->value);
                r->next = p;
                r = p;
            }
            r->next = NULL;
            return 1;
        }
        return 0;
    }
     
    void displist(node* l)
    {
        node* p;
        if (l)
        {
            p = l;
            while (p->next != NULL)
            {
                p = p->next;
                printf("%d\t", p->value);
            }
        }
    }
    int main()
    {
        node* l;
        l = (node*)malloc(sizeof(node));
        int x[10] = { 1,2,3,4,5,6,7,8,9,10 },STATUS=0;
        STATUS = creatlistf(l, x, 10);//&号去掉 
        displist(l);//&号去掉 
        return 0;
    }
     
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论 编辑记录
查看更多回答(2条)

报告相同问题?

问题事件

  • 系统已结题 4月1日
  • 已采纳回答 3月24日
  • 修改了问题 3月24日
  • 修改了问题 3月24日
  • 展开全部

悬赏问题

  • ¥20 iOS绕地区网络检测
  • ¥15 python验证码滑块图像识别
  • ¥15 根据背景及设计要求撰写设计报告
  • ¥15 QT6颜色选择对话框显示不完整
  • ¥20 能提供一下思路或者代码吗
  • ¥15 用twincat控制!
  • ¥15 请问一下这个运行结果是怎么来的
  • ¥15 单通道放大电路的工作原理
  • ¥30 YOLO检测微调结果p为1
  • ¥15 DS18B20内部ADC模数转换器