鱼C论坛

 找回密码
 立即注册
查看: 936|回复: 1

[已解决]如何对成绩进行排序啊

[复制链接]
发表于 2023-11-10 20:33:23 | 显示全部楼层 |阅读模式

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

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

x
题目描述
又到了一学期一度的考试周,老师要开始统计大家的成绩了。

从键盘上按学号输入n
个学生的数据(包括姓名,三门课的成绩),按照总成绩从高到低排序,

并输出学生的姓名、学号和总分。

输入描述
第一行一个整数n
,表示n
个学生;

接下来n
行,每行包括一个字符串,表示学生姓名,三个整数,表示三门课的成绩。

输出描述
输出n
行,表示按照总分从高到低排序后学生的信息,包括姓名、学号和总分,以空格分开。

创建了学生类;输入数据后如何按成绩给学生排序啊
#include<bits/stdc++.h>
using namespace std;
class Student
{
    public:
    string Name;
    int Id;
    int a,b,c;
    int sum;
    Student()
    {
        sum=0;
    }
    void zong()
    {
        sum=a+b+c;
    }
};
int main()
{
    Student s[110]
    int n;
    cin>>n;int i=0;
    while(n--)
    {
        cin>>s[i].Name>>s[i].a>>s[i].b>>s[i].c;
        i++;
        s[i-1].Id=i;
        s[i].zong();
    }
}
最佳答案
2023-11-10 20:33:32
#include <iostream>
#include <algorithm>
using namespace std;

class Student
{
public:
    string Name;
    int Id;
    int a, b, c;
    int sum;
    Student()
    {
        sum = 0;
    }
    void zong()
    {
        sum = a + b + c;
    }
};

bool compare(Student s1, Student s2)
{
    return s1.sum > s2.sum;
}

int main()
{
    Student s[110];
    int n;
    cin >> n;
    int i = 0;
    while (n--)
    {
        cin >> s[ i].Name >> s[ i].a >> s[ i].b >> s[ i].c;
        s[ i].Id = i + 1;
        s[ i].zong();
        i++;
    }

    sort(s, s + i, compare);

    for (int j = 0; j < i; j++)
    {
        cout << s[j].Name << " " << s[j].Id << " " << s[j].sum << endl;
    }
    return 0;
}
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2023-11-10 20:33:32 | 显示全部楼层    本楼为最佳答案   
#include <iostream>
#include <algorithm>
using namespace std;

class Student
{
public:
    string Name;
    int Id;
    int a, b, c;
    int sum;
    Student()
    {
        sum = 0;
    }
    void zong()
    {
        sum = a + b + c;
    }
};

bool compare(Student s1, Student s2)
{
    return s1.sum > s2.sum;
}

int main()
{
    Student s[110];
    int n;
    cin >> n;
    int i = 0;
    while (n--)
    {
        cin >> s[ i].Name >> s[ i].a >> s[ i].b >> s[ i].c;
        s[ i].Id = i + 1;
        s[ i].zong();
        i++;
    }

    sort(s, s + i, compare);

    for (int j = 0; j < i; j++)
    {
        cout << s[j].Name << " " << s[j].Id << " " << s[j].sum << endl;
    }
    return 0;
}
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-10-5 11:20

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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