链表求助
本人是一位自学c语言的小白,刚刚看小甲鱼自学了c语言的链表,就想自己试一下动态存储,然后就出了点问题,求大神帮助一下:#include <stdio.h>
#include <stdlib.h>
struct student
{
int num;
float score;
struct student *next;
}p1, p2, *head;//一个普通的结构体
int main()
{
int n = 0;
p2.next = (struct student*)malloc(sizeof(struct student));//给p2的next分配一个初始内存
do
{
printf("请输入学生信息:\n学号:");
scanf_s("%d", &p2.num);
if (p2.num == 0)break;//学号为0时跳出循环
printf("分数:");
scanf_s("%f", &p2.score);
printf("\n");//输入信息
n++;//计数
if (n == 1)
{
p1 = p2;
head = &p1;//头指向p1
p1.next = p2.next;//链接节点
}
else
{
*p2.next = p2;
p2.next = (struct student*)calloc(1, sizeof(struct student));//添加节点
p2.next->next = p2.next;
}
} while (p1.num != 0);
p2.next->next = NULL;//设置尾
if (p1.num != 0)
{
do
{
printf("学号:%d\t\t分数:%f\n", head->num, head->score);//输出内容
head = head->next;
printf("\n%d\t%d\n", head, head->next);//输出地址
} while (head != NULL);
}
return 0;
}
结果如下:
file:///C:\Users\Administrator\AppData\Roaming\Tencent\Users\793251242\QQ\WinTemp\RichOle\1Z@7~`O_P`U4YT%VMYX95UT.png
file:///C:\Users\Administrator\AppData\Roaming\Tencent\Users\793251242\QQ\WinTemp\RichOle\62BEK}]0}3$[~CR_6}RQ7}T.png
学生2 在一直循环输出,地址也没有变,
这个问题已经研究好几天了,求大神帮助
页:
[1]