#include<stdio.h>
#include<malloc.h>
#define elemType int
//定义数据元素
typedef struct LNode{
elemType data; //数据域
struct LNode *next; //指针域
}LNode,*List;
//头插法创建单链表
List ListHeadInsert(List p){
List s;
int x;
p = (List)malloc(sizeof(LNode)); //创建空结点
p->next = NULL;
printf("请输入数据(以9999结束):\n");
scanf("%d",&x);
while(x!=9999){
s = (List)malloc(sizeof(LNode));
s->data = x;
s->next = p->next;
p->next=s;
scanf("%d",&x);
}
return p;
}
//打印单链表
List PrintList(List p){
printf("调用成功");
while(p){
printf("%d",p->data);
p=p->next;
}
// if(!p->next){
// printf("该单链表为空链表");
// }
return p;
}
int main(){
List p ;
ListHeadInsert(p);
printf("创建成功\n");
PrintList(p);
}
单链表 为什么不能打印出单链表 能够调用函数
- 写回答
- 好问题 0 提建议
- 追加酬金
- 关注问题
- 邀请回答
-
2条回答 默认 最新
- qfl_sdu 2021-09-13 16:09关注
ListHeadInsert函数逻辑写错了,给你改一下
#include<stdio.h> #include<malloc.h> #define elemType int //定义数据元素 typedef struct LNode{ elemType data; //数据域 struct LNode *next; //指针域 }LNode,*List; //头插法创建单链表 List ListHeadInsert(List p){ List s,tt; //修改1,多声明一个变量 int x; p = (List)malloc(sizeof(LNode)); //创建空结点 p->next = NULL; tt = p; //修改2,下面的操作用tt,避免改变p的值 printf("请输入数据(以9999结束):\n"); scanf("%d",&x); while(x!=9999){ s = (List)malloc(sizeof(LNode)); s->data = x; s->next = NULL;//p->next; 修改3 tt->next = s ;//p->next=s; 修改4 tt = s; //修改5 scanf("%d",&x); } return p; } //打印单链表 void PrintList(List p){ //修改5,打印函数不用返回 List t = p->next; //修改6:因为你的头结点中没有存放数据,所以从p->next开始遍历输出 printf("调用成功"); while(t){ printf("%d",t->data); t=t->next; } // if(!p->next){ // printf("该单链表为空链表"); // } //return p; //打印函数,不用再返回了 } int main(){ List p = 0 ; ListHeadInsert(p); printf("创建成功\n"); PrintList(p); return 0; }
本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 无用评论 打赏 举报
悬赏问题
- ¥15 做个有关计算的小程序
- ¥15 MPI读取tif文件无法正常给各进程分配路径
- ¥15 如何用MATLAB实现以下三个公式(有相互嵌套)
- ¥30 关于#算法#的问题:运用EViews第九版本进行一系列计量经济学的时间数列数据回归分析预测问题 求各位帮我解答一下
- ¥15 setInterval 页面闪烁,怎么解决
- ¥15 如何让企业微信机器人实现消息汇总整合
- ¥50 关于#ui#的问题:做yolov8的ui界面出现的问题
- ¥15 如何用Python爬取各高校教师公开的教育和工作经历
- ¥15 TLE9879QXA40 电机驱动
- ¥20 对于工程问题的非线性数学模型进行线性化