我在编写C语言建立一个单链表存储数据,运行没报错,却出现联机调试等对话框,希望大神看看哪里有错误。

#include<stdio.h>#include<stdlib.h>#include<malloc.h>typedefstruct//建立一个结构体{intdate;s... #include<stdio.h>
#include<stdlib.h>
#include<malloc.h>
typedef struct//建立一个结构体
{
int date;
struct sqlist*next;//结构体指针
}sqlist;
int creat()//构建一个单链表
{
sqlist *p, *h,*s;
if (h = (sqlist *)malloc(sizeof(sqlist)) == NULL)
{
printf("分配失败\n");
exit(0);
}
h->next = NULL;
p = h;
for (int i = 0; p!=NULL; i++)
{
if(s= (sqlist *)malloc(sizeof(sqlist)) == NULL)
{
printf("分配失败\n");
exit(0);
}
p->next = s;
scanf_s("%d", &s->date);
s->next = NULL;
p = s;
}
return h;
}
int print(sqlist *h)
{
sqlist *p;
p = h;
for (int i = 0; i < 4; i++)
{
printf("%d ", p->date);
p = p->next;
}
}
int main()
{
sqlist *head=creat();
print(head);
}
展开
 我来答
风若远去何人留
2016-10-15 · 知道合伙人互联网行家
风若远去何人留
知道合伙人互联网行家
采纳数:20412 获赞数:450134
专业C/C++软件开发

向TA提问 私信TA
展开全部

三个问题

1 creat函数返回值 应该是sqlist * 而不是int

2 头结点没有存数据,打印的时候应该略过头结点

3 作为链表,不应该在打印的时候用for (int i = 0; i < 4; i++) 这样的方式,而应该判断next是否为空。

void print(sqlist *h)
{
sqlist *p;
p = h->next;
for (; p; p=p->next)
{
printf("%d ", p->date);
}
}
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式