shotar0 2022-09-14 00:17 采纳率: 57.1%
浏览 47
已结题

C语言单链表输出数据

问题遇到的现象和发生背景

C语言单链表输出数据把头指针也输出来了?

问题相关代码,请勿粘贴截图
#include<stdio.h>
#include<stdlib.h>
#include<malloc.h>
typedef int ElemType;
#include"SingleLinklist.h"
int Insert(int num,SingleLinklist *head,int length)
{
    int j=-1;
    SingleLinklist *p;
    p=head;
    while(p->next!=NULL&&j<length)
    {
        if(num>=p->data)
        {
            p=p->next;j++;
        }
        else
            {
                ListInsert(p,j,num);    
            }
    }
}
int main()
{
    SingleLinklist *head;
    int i=0,length=0;
    int num;
    ListInitialize(&head);
    do
    {
        scanf("%d",&num);
        ListInsert(head,i,num);
        length++;
        i++;
    }while(getchar()==' ');
    printf("当前表的数据有如下:\n");
    putlist(head);

以下为自定义的头文件:

#include<malloc.h>
#include<stdio.h>
#include<stdlib.h> 
typedef struct SingleNode{
    ElemType data;
    struct SingleNode *next;
}SingleLinklist,*Linklist;
void ListInitialize(SingleLinklist * *head)
{
    if((*head=(SingleLinklist *) malloc(sizeof(SingleLinklist)))==NULL)
    {
        printf("建表失败!");
        exit(1);
    }
    (*head)->next=NULL;
}
int ListLength(SingleLinklist *head)
{
    SingleLinklist *p=head;
    int size =0;
    while(p->next!=NULL)
    {
        p=p->next;
        size ++;
    }
    return size;
}
int ListGet(SingleLinklist *head,int i,ElemType *x)
{
    SingleLinklist *p;
    int j;
    p=head;
    j=-1;
    while(p->next!=NULL&&j<i)
    {
        p=p->next;
        j++;
    }
    if(j!=i)
    {
        printf("取元素位置出错");
        return 0;
    }
    *x=p->data;
    return 1;
}
int ListInsert(SingleLinklist *head,int i,ElemType x)
{
    SingleLinklist  *p,*q;
    int j;
    p=head;
    j=-1;
    while(p->next!=NULL&&j<i-1)
    {
        p=p->next;
        j++;
    }
    if(j!=i-1)
    {
        printf("插入位置出错!");
        return 0; 
    }
    if((q=(SingleLinklist *) malloc (sizeof(SingleLinklist)))==NULL)
    {
        exit(1);
    }
    q->data=x;
    q->next=p->next;
    p->next=q;
    return 1;
}
int ListDelete(SingleLinklist *head,int i,ElemType *x)
{
    SingleLinklist *p,*s;
    int j;
    p=head;
    j=-1;
    while(p->next!=NULL&&p->next!=NULL&&j<i-1)
    {
        p=p->next;
        j++;
    }
    if(j!=i-1)
    {
        printf("删除位置出错!");
        return 0;
    }
    s=p->next;
    *x=s->data;
    p->next=s->next;
    free(s);
    return 1;
}
void Destroy(SingleLinklist **head)
{
    SingleLinklist *p,*p1;
    p=*head;
    while(p!=NULL)
    {
        p1=p;
        p=p->next;
        free(p1);
        
    }
    *head=NULL;
}
void putlist(SingleLinklist *head)
{
    SingleLinklist *p;
    p=head;
    while(p!=NULL)
    {
        printf("%5d",p->data);
        p=p->next;
    }
}

运行结果及报错内容

img

  • 写回答

3条回答 默认 最新

  • 日向晚,声声慢 2022-09-14 07:36
    关注

    img


    p的指向错了

    img

    img

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(2条)

报告相同问题?

问题事件

  • 系统已结题 9月22日
  • 已采纳回答 9月14日
  • 创建了问题 9月14日

悬赏问题

  • ¥15 装 pytorch 的时候出了好多问题,遇到这种情况怎么处理?
  • ¥20 IOS游览器某宝手机网页版自动立即购买JavaScript脚本
  • ¥15 手机接入宽带网线,如何释放宽带全部速度
  • ¥30 关于#r语言#的问题:如何对R语言中mfgarch包中构建的garch-midas模型进行样本内长期波动率预测和样本外长期波动率预测
  • ¥15 ETLCloud 处理json多层级问题
  • ¥15 matlab中使用gurobi时报错
  • ¥15 这个主板怎么能扩出一两个sata口
  • ¥15 不是,这到底错哪儿了😭
  • ¥15 2020长安杯与连接网探
  • ¥15 关于#matlab#的问题:在模糊控制器中选出线路信息,在simulink中根据线路信息生成速度时间目标曲线(初速度为20m/s,15秒后减为0的速度时间图像)我想问线路信息是什么