为什么会出现这种结果?

酱料& 2021-03-25 12:27:04
#include<stdio.h> #include<stdlib.h> typedef int datatype; typedef struct node { datatype data; struct node *next; }linklist; void creatlist1(linklist *head,int n) { linklist *p,*s; int i; head->next=NULL; s=head; for(i=0;i<n;i++) { p=(linklist*)malloc(sizeof(linklist)); scanf("%d",&p->data); s->next=p; s=p; } } void displaylist(linklist *head) { linklist *p; int i=0; p=head->next; if(p==NULL) { printf("这是个空指针\n"); } while(p) { printf("%d ",p->data); p=p->next; } } int main() { linklist *head; head=(linklist*)malloc(sizeof(linklist)); creatlist1(head,5); //创建一个链式列表 displaylist(head); //输出列表中的元素 return 0; }
...全文
145 5 打赏 收藏 转发到动态 举报
写回复
用AI写文章
5 条回复
切换为时间正序
请发表友善的回复…
发表回复
源代码大师 2021-05-03
  • 打赏
  • 举报
回复
C和C++完整教程:https://blog.csdn.net/it_xiangqiang/category_10581430.html C和C++算法完整教程:https://blog.csdn.net/it_xiangqiang/category_10768339.html
自信男孩 2021-03-25
  • 打赏
  • 举报
回复
#include<stdio.h>
#include<stdlib.h>

typedef int datatype;
typedef struct node
{
datatype data;
struct node *next;
}linklist;

void creatlist1(linklist *head,int n)
{
linklist *p,*s;
int i;

head->next=NULL;
s=head;
for(i=0;i<n;i++)
{
p=(linklist*)malloc(sizeof(linklist));
scanf("%d",&p->data);
s->next=p;
s=p;
}

s->next = NULL; //last node's next pointer NULL
}
void displaylist(linklist *head)
{
linklist *p;
//int i=0;
p=head->next;
if(p==NULL)
{
printf("这是个空指针\n");
return; //exit from displylist
}
while(p)
{

printf("%d ",p->data);
p=p->next;
}
}
int main()
{
linklist *head;
head=(linklist*)malloc(sizeof(linklist));
creatlist1(head,5); //创建一个链式列表
displaylist(head); //输出列表中的元素
return 0;
}

供参考~

原因是创建链表的时候没有对最后一个节点做处理,即最后一个节点的next指针应该指向NULL
displaylist出现无限循环就是因为没有找到NULL
赵4老师 2021-03-25
  • 打赏
  • 举报
回复
数据结构对单链表进行数据排序 http://bbs.csdn.net/topics/392201633
棉猴 2021-03-25
  • 打赏
  • 举报
回复
正如楼上朋友说的,代码产生问题的主要原因在于displaylist()函数的
while (p)
	{
		printf("%d ", p->data);
		p = p->next;
	}
在遍历链表的时候,最后一个元素时,理论上p->next应该指向空指针,但是由于createlist1()函数的for循环中分配内存时,并没有对p->next值进行显式地赋空指针值,导致最后一个元素的p->next不是空指针而是一个随机值,在我调试的VS2015中,这个值是0xcdcdcdcd。这样就导致在displaylist()函数的while()语句中会访问0xcdcdcdcd,而这个地址是不能访问的,就会直接报错。 解决的方法就是在createlist1()函数的for循环中
p = (linklist*)malloc(sizeof(linklist));
		p->next = nullptr;
真相重于对错 2021-03-25
  • 打赏
  • 举报
回复
p=(linklist*)malloc(sizeof(linklist)); p->next=NULL
【更新至2025年】2001-2025年上市公司数字化转型年报词频统计(吴非、赵宸宇、甄红线)(300+年报词频统计) 1、时间:2001-2025年 2、来源:上市公司年报 3、参考文献:企业数字化转型与资本市场表现——来自股票流动性的经验证据(吴非) 数字化转型如何影响企业全要素生产率(赵宸宇) 知识产权行政保护与企业数字化转型(甄红线) 4、方法说明:(1)参考吴非老师的做法,对人工智能技术、大数据技术、云计算技术、区块链技术、数字技术运用五个维度76个数字化相关词频进行统计 (2)参考赵宸宇老师的做法,对数字技术应用、互联网商业模式、智能制造、现代信息系统四个维度99个数字化相关词频进行统计 (3)参考甄红线老师的做法,对技术分类、组织赋能、数字化应用等类别下139个数字化相关词频进行统计 5、指标:年份、股票代码、公司简称、行业名称、行业代码、全文-文本总长度、仅中英文-文本总长度、人工智能技术-吴、大数据技术-吴、云计算技术-吴、区块链技术-吴、数字技术运用-吴、数字技术应用-赵、互联网商业模式-赵、智能制造-赵、现代信息系统-赵、技术分类-人工智能技术-甄、技术分类-区块链技术-甄、技术分类-云计算技术-甄、技术分类-大数据技术-甄、组织赋能-人工智能技术-甄、组织赋能-云计算技术-甄、组织赋能-大数据技术-甄、组织赋能-广义数字技术-甄、数字化应用-技术创新-甄、数字化应用-流程创新-甄、数字化应用-业务创新-甄、人工智能、商业智能、图像理解、投资决策辅助系统、智能数据分析、智能机器人、机器学习、深度学习、语义搜索、生物识别技术、人脸识别、语音识别、身份验证、自动驾驶、自然语言处理、大数据、数据挖掘、文本挖掘、数据可视化、异构数据、征信、增强现实、混合现实、虚拟现实、云计算、流计算、图计算、内存计算、多方安全计算、类脑计算、绿色计算、认知计算等300+词频

70,038

社区成员

发帖
与我相关
我的任务
社区描述
C语言相关问题讨论
社区管理员
  • C语言
  • 花神庙码农
  • 架构师李肯
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧