鱼C论坛

 找回密码
 立即注册
查看: 1553|回复: 0

[技术交流] 链表求助

[复制链接]
发表于 2019-2-2 20:23:30 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
本人是一位自学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

[img]file:///C:\Users\Administrator\AppData\Roaming\Tencent\Users\793251242\QQ\WinTemp\RichOle\62BEK}]0}3$[~CR_6}RQ7}T.png[/img]

学生2 在一直循环输出,地址也没有变,
这个问题已经研究好几天了,求大神帮助
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-1-17 14:24

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表