小影好困 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 centos7.9脚本,怎么排除特定的访问记录
  • ¥15 关于#Django#的问题:我的静态文件呢?
  • ¥15 关于CPLEX的问题,请专家解答
  • ¥15 cocos的点击事件 怎么穿透到 原生fragment上。
  • ¥20 基于相关估计的TDOA算法中的加权最小二乘拟合法matlab仿真
  • ¥20 基于相关估计的TDOA算法中的自适应加权广义互相关法。
  • ¥15 abaqus CAE 2024软件启动问题
  • ¥20 基于相关估计的TDOA算法中的局部互相关函数滤波matlab仿真
  • ¥15 CDH6.0.1 hue报错
  • ¥15 javaFX利用scene builder的fxml文件进行开发时的label setText方法未生效问题