反方向顺流的船 2022-10-02 15:20 采纳率: 60%
浏览 283
已结题

创建链表的问题,希冀平台

问题遇到的现象和发生背景

创建链表问题:提交与自己学号相邻的两位同学的学号与一门考试成绩,编程建立由这三组数据结点组成的简单链表。
我在CSDN上允许各种案例,输出都是正确的,但是到了希冀平台上就是输出有问题

用代码块功能插入代码,请勿粘贴截图

#include <stdio.h>
#include <stdlib.h>
typedef struct Lnode* node;
struct Lnode
{
int num, score;
struct Lnode next;
};
node createlist()
{
struct Lnode lis=(struct Lnode)malloc(sizeof(struct Lnode));
lis->next = NULL;
lis->num = 0;
return lis;
}
void addelement(struct Lnode
p)
{
struct Lnode newone= (struct Lnode)malloc(sizeof(struct Lnode));
newone->next = NULL;
struct Lnode* nextp=p;
for (int i = 0; i < p->num; i++)
nextp = nextp->next;
nextp->next = newone;
p->num++;

scanf("%d,%d", &newone->num, &newone->score);

}
void outelement(struct Lnode* p)
{
struct Lnode* nextp = p;

for (int t = 0; t < p->num; t++)
{
    printf("[num=%d,score=%d]", nextp->next->num, nextp->next->score);
    if (i != p->num - 1)
        printf("\n");
    nextp = nextp->next;
}

}
int main()
{
struct Lnode *p;
p = createlist();
for (int t= 0; t < 3; i++)
{
addelement(p);

}
    outelement(p);
return 0;

}

运行结果及报错内容

img

我的解答思路和尝试过的方法

有思考过空格问题,但是改了几次还是不行

  • 写回答

4条回答 默认 最新

  • qzjhjxj 2022-10-02 17:28
    关注

    重新修改,输入时注意学号和分数间的逗号 ‘,' 是英文半角的,供参考:

    #include <stdio.h>
    #include <stdlib.h>
    typedef struct Lnode* node;
    struct Lnode
    {
        int num, score;
        struct Lnode* next;
    };
    node createlist()
    {
        struct Lnode* lis = (struct Lnode*)malloc(sizeof(struct Lnode));
        lis->next = NULL;
        lis->num = 0;
        return lis;
    }
    void addelement(struct Lnode* p)
    {
        struct Lnode* newone = (struct Lnode*)malloc(sizeof(struct Lnode));
        newone->next = NULL;
        scanf("%d,%d", &newone->num, &newone->score);
        struct Lnode* nextp = p;
        for (nextp = p;nextp->next != NULL; nextp = nextp->next);
        nextp->next = newone;
        p->num++;
    }
    void outelement(struct Lnode* p)
    {
        struct Lnode* nextp = p;
        for (nextp = p;nextp->next != NULL;nextp = nextp->next)
        {
            printf("[num=%d,score=%d]", nextp->next->num, nextp->next->score);
            if (nextp->next->next != NULL)
                printf("\n");
        }
    }
    int main()
    {
        struct Lnode *p;
        p = createlist();
        for (int t = 0; t < 3; t++)
        {
             addelement(p);
        }
        outelement(p);
        return 0;
    }
    
    

    img

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论 编辑记录
查看更多回答(3条)

报告相同问题?

问题事件

  • 系统已结题 10月10日
  • 已采纳回答 10月2日
  • 创建了问题 10月2日

悬赏问题

  • ¥15 基于stm32f4产生两路pwm信号并可由串口通信调节
  • ¥15 C++/QT设置函数调用条件(多个功能调用同一,且各自调用条件不同)
  • ¥15 UE5样条线生成的网格UV问题
  • ¥15 如何用最短的时间大致看懂springboot+vue的项目
  • ¥15 (有偿)懂数值分析和含时变参数微分方程的来
  • ¥15 abaqus随机生成二维颗粒
  • ¥15 安装ansys许可证管理器时出现了这个问题,如何解决?
  • ¥100 高价求算法,利用智能手机传感器计算车辆的三轴g值
  • ¥15 uni-app开发APP运行到浏览器访问接口跨域
  • ¥100 mfc消息自创建控件