沉迷摸鱼无法自拔 2022-07-24 11:06 采纳率: 70.6%
浏览 97
已结题

请问这个问题怎么解决

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

定义一个学生结构体类型student,包括4个字段,姓名、性别、年龄和成绩。然后在主函数中定义一个结构体数组(长度不超过1000),并输入每个元素的值,程序使用冒泡排序法将学生按照成绩从小到大的顺序排序,然后输出排序的结果。

问题相关代码,请勿粘贴截图
#include<stdio.h>
#include<stdlib.h>
struct student {
    char name[21];
    char sex[7];
    int age;
    int score;
};
int main()
{
    int  n, i, j;
    printf("请输入学生数:(学生数量<10000)");
    scanf_s("%d", n);
    struct student stu[n], t;
    for (i = 0; i < n; i++)
    {
        printf("请输入第%d个学生:", n + 1);
        scanf_s("%s%s%d%d", &stu[i].name, &stu[i].sex, &stu[i].age, &stu[i].score);
    }
    for (i = 0; i < n; i++)
    {
        for (j = n - 1; j > i; j--)
        {
            if (stu[j - 1].score > stu[j].score)
            {
                t = stu[j];
                stu[j] = stu[j - 1];
                stu[j - 1] = t;
            }
        }
        printf("%s  %s  %d  %d\n", stu[i].name, stu[i].sex, stu[i].score);
    }
    return 0;
}


运行结果及报错内容
严重性    代码    说明    项目    文件    行    禁止显示状态
错误    C2131    表达式的计算结果不是常数    ConsoleApplication3    c:\users\jd\source\repos\consoleapplication3\consoleapplication3\consoleapplication3.cpp    341    
严重性    代码    说明    项目    文件    行    禁止显示状态
错误    C3863    不可指定数组类型“student [n]”    ConsoleApplication3    c:\users\jd\source\repos\consoleapplication3\consoleapplication3\consoleapplication3.cpp    354    


  • 写回答

2条回答 默认 最新

  • fuill 2022-07-24 15:25
    关注

    img


    修改见注释
    有问题可以回复

    #include<stdio.h>
    #define max 10000
    struct student
    {
        char name[21];
        char sex[7];
        int age;
        int score;
    };
    int main()
    {
        int  n, i, j;
        printf("请输入学生数:(学生数量<%d)",max);
        scanf_s("%d", &n);//加了&
        struct student stu[max], t;
        for (i = 0; i < n; i++)
        {
            printf("请输入第%d个学生:", i + 1);//改成i+1
            scanf_s("%s%s%d%d", stu[i].name,20, stu[i].sex,6, &stu[i].age, &stu[i].score);//输入字符串不用&,后面跟字符串长度 
        }
        for (i = 0; i < n - 1 ; i++)//冒泡排序 
        {
            for (j = 0; j <n - i - 1 ; j++)
            {
                if (stu[j].score > stu[ j + 1 ].score)
                {
                    t = stu[j];
                    stu[j] = stu[j + 1];
                    stu[j + 1] = t;
                }
            }
            for (i = 0; i < n; i++)//遍历输出 
            {
                printf("%s  %s  %d  %d\n", stu[i].name, stu[i].sex, stu[i].age, stu[i].score);
            }
        }
        return 0;
    }
    
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论 编辑记录
查看更多回答(1条)

报告相同问题?

问题事件

  • 系统已结题 8月2日
  • 已采纳回答 7月25日
  • 创建了问题 7月24日

悬赏问题

  • ¥35 平滑拟合曲线该如何生成
  • ¥100 c语言,请帮蒟蒻写一个题的范例作参考
  • ¥15 名为“Product”的列已属于此 DataTable
  • ¥15 安卓adb backup备份应用数据失败
  • ¥15 eclipse运行项目时遇到的问题
  • ¥15 关于#c##的问题:最近需要用CAT工具Trados进行一些开发
  • ¥15 南大pa1 小游戏没有界面,并且报了如下错误,尝试过换显卡驱动,但是好像不行
  • ¥15 没有证书,nginx怎么反向代理到只能接受https的公网网站
  • ¥50 成都蓉城足球俱乐部小程序抢票
  • ¥15 yolov7训练自己的数据集