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日

悬赏问题

  • ¥50 STM32L431RCT6 定时器2中断发起ADC 采样问题
  • ¥15 如何通过交互分析得出某高危患者对放疗获益更多
  • ¥15 相关性分析中,p<0.05, r=0.29,怎么评价相关性呢
  • ¥15 docker部署Mongodb后输入命令报错?
  • ¥15 将下列流程图转变成python程序代码
  • ¥15 我需要全国每个城市的最新小区名字等数据。
  • ¥15 开发一个小区生态的小程序
  • ¥15 如何解决Excel中dependent dropdown list 的问题
  • ¥15 MddBootstrapInitialize2失败
  • ¥15 LCD Flicker