小影好困 2022-05-06 07:54 采纳率: 100%
浏览 47
已结题

C语言结构体排序遇到问题

题目要求输入20名学生的学号 名字 作 业(20%)考勤(10%)和期 末(70%)成绩并在求出总分后按总分从大到小排序

我在写排序的过程中遇到了困难,请告诉我怎么写,谢谢

#include <stdio.h>
#define N 5
struct student
{
    int no;
    char name[20];
    int kaoqing;
    int zuoye;
    int qimo;
};

int main(void)
{
    int i, sum = 0 ;
    struct student stu[N] = {0}, temp;
    puts("Please enter information of student: ");
    for (i = 0; i < N; i++)
    {
        scanf("%d %s %d %d %d", &stu[i].no, stu[i].name, &stu[i].kaoqing, &stu[i].zuoye, &stu[i].qimo);
    }

    for (i = 0; i < N; i++)
    {
        sum++;
        // 考勤10%作业20%期末70%
        printf(" ID=%d Name=%s check_in=%f zuoye=%f qimo=%f sum=%f\n", stu[i].no, stu[i].name, stu[i].kaoqing * 0.1, stu[i].zuoye * 0.2, stu[i].qimo * 0.7, (stu[i].kaoqing * 0.1) + (stu[i].zuoye * 0.2) + (stu[i].qimo * 0.7));
    }

    return 0;
}

```

  • 写回答

3条回答 默认 最新

  • 关注

    总分按照你的公式计算出来,写个冒泡排序就可以了。代码如下:

    #include <stdio.h>
    #define N 5
    struct student
    {
        int no;
        char name[20];
        int kaoqing;
        int zuoye;
        int qimo;
    };
    
    int main(void)
    {
        int i, sum = 0;
        int j;
        struct student stu[N] = { 0 }, temp;
        double t1, t2;
        puts("Please enter information of student: ");
        for (i = 0; i < N; i++)
        {
            scanf("%d %s %d %d %d", &stu[i].no, stu[i].name, &stu[i].kaoqing, &stu[i].zuoye, &stu[i].qimo);
        }
    
        //排序
        for (i = 0; i < N - 1; i++)
        {
            for (j = 0; j < N - 1 - i; j++)
            {
                t1 = stu[j].zuoye * 0.2 + stu[j].kaoqing * 0.1 + stu[j].qimo * 0.7;
                t2 = stu[j+1].zuoye * 0.2 + stu[j+1].kaoqing * 0.1 + stu[j+1].qimo * 0.7;
                if (t1 < t2)
                {
                    temp = stu[j];
                    stu[j] = stu[j + 1];
                    stu[j + 1] = temp;
                }
            }
        }
    
    
        //显示结果
        for (i = 0; i < N; i++)
        {
            printf(" ID=%d Name=%s check_in=%f zuoye=%f qimo=%f sum=%f\n", stu[i].no, stu[i].name, stu[i].kaoqing * 0.1, stu[i].zuoye * 0.2, stu[i].qimo * 0.7, (stu[i].kaoqing * 0.1) + (stu[i].zuoye * 0.2) + (stu[i].qimo * 0.7));
        }
    
        return 0;
    }
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论 编辑记录
查看更多回答(2条)

报告相同问题?

问题事件

  • 系统已结题 5月14日
  • 已采纳回答 5月6日
  • 创建了问题 5月6日

悬赏问题

  • ¥15 stata安慰剂检验作图但是真实值不出现在图上
  • ¥15 c程序不知道为什么得不到结果
  • ¥40 复杂的限制性的商函数处理
  • ¥15 程序不包含适用于入口点的静态Main方法
  • ¥15 素材场景中光线烘焙后灯光失效
  • ¥15 请教一下各位,为什么我这个没有实现模拟点击
  • ¥15 执行 virtuoso 命令后,界面没有,cadence 启动不起来
  • ¥50 comfyui下连接animatediff节点生成视频质量非常差的原因
  • ¥20 有关区间dp的问题求解
  • ¥15 多电路系统共用电源的串扰问题