c++活泼虾 2022-12-31 12:10 采纳率: 66.7%
浏览 52
已结题

1839:【05NOIP提高组】谁拿了最多奖学金

1839:【05NOIP提高组】谁拿了最多奖学金
【题目描述】
某校的惯例是在每学期的qm考试之后发放奖学金。发放的奖学金共有五种,获取的条件各自不同:

1)院士奖学金,每人8000元,期末平均成绩高于80分(>80),并且在本学期内发表1篇或1篇以上论文的学生均可获得;

2)五四奖学金,每人4000元,期末平均成绩高于85分(>85),并且班级评议成绩高于80分(>80)的学生均可获得;

3)成绩优秀奖,每人2000元,期末平均成绩高于90分(>90)的学生均可获得;

4)西部奖学金,每人1000元,期末平均成绩高于85分(>85)的西部省份学生均可获得;

5)班级贡献奖,每人850元,班级评议成绩高于80分(>80)的学生干部均可获得;

只要符合条件就可以得奖,每项奖学金的获奖人数没有限制,每名学生也可以同时获得多项奖学金。例如姚林的期末平均成绩是87分,班级评议成绩82分,同时他还是一位学生干部,那么他可以同时获得五四奖学金和班级贡献奖,奖金总数是4850元。

现在给出若干学生的相关数据,请计算哪些同学获得的奖金总数最高(假设总有同学能满足获得奖学金的条件)。

【输入】
第一行是一个整数N(1 <= N <= 100),表示学生的总数。接下来的N行每行是一位学生的数据,从左向右依次是姓名,期末平均成绩,班级评议成绩,是否是学生干部,是否是西部省份学生,以及发表的论文数。姓名是由大小写英文字母组成的长度不超过20的字符串(不含空格);期末平均成绩和班级评议成绩都是0到100之间的整数(包括0和100);是否是学生干部和是否是西部省份学生分别用一个字符表示,Y表示是,N表示不是;发表的论文数是0到10的整数(包括0和10)。每两个相邻数据项之间用一个空格分隔。

【输出】
三行,第一行是获得最多奖金的学生的姓名,第二行是这名学生获得的奖金总数。如果有两位或两位以上的学生获得的奖金最多,输出他们之中在输入文件中出现最早的学生的姓名。第三行是这N个学生获得的奖学金的总数。

【输入样例】
4
YaoLin 87 82 Y N 0
ChenRuiyi 88 78 N Y 1
LiXin 92 88 N N 0
ZhangQin 83 87 Y N 1
【输出样例】
ChenRuiyi
9000
28700
【代码】(错误)

#include<bits/stdc++.h>
using namespace std;
struct node{
    string name;
    int qmcj,bjcj,lw,jj;
    char gb,xb;
}a[1000];
bool none(node a,node b)
{
    if(a.jj<b.jj)return 0;
    else return 1;
}
int nome(node a)
{
    int sum=0;
    if(a.qmcj>80&&a.lw>0)sum+=8000;
    if(a.qmcj>85&&a.bjcj>80)sum+=4000;
    if(a.qmcj>90)sum+=2000;
    if(a.qmcj>85&&a.xb=='Y')sum+=1000;
    if(a.bjcj>80&&a.gb=='Y')sum+=850;
    return sum;
}
int main()
{
    int n,sum=0;
    cin>>n;
    for(int i=0;i<n;i++)
    {
        cin>>a[i].name>>a[i].qmcj>>a[i].bjcj>>a[i].gb>>a[i].xb>>a[i].lw;
        a[i].jj=nome(a[i]);
    }
    sort(a,a+n,none);
    cout<<a[0].name<<endl<<a[0].jj<<endl;
    for(int i=0;i<n;i++)
    {
        sum+=a[i].jj;
    }
    cout<<sum;
    return 0;
}

未通过 0分
测试点1: 运行错误 616KB 5MS
测试点2: 运行错误 620KB 4MS
测试点3: 运行错误 612KB 4MS
测试点4: 运行错误 608KB 5MS
测试点5: 运行错误 616KB 5MS
测试点6: 运行错误 612KB 5MS
测试点7: 运行错误 612KB 5MS
测试点8: 运行错误 620KB 5MS
测试点9: 运行错误 616KB 5MS
测试点10: 运行错误 608KB 5MS
大佬们请帮我看看!

  • 写回答

1条回答 默认 最新

  • heart_6662 2022-12-31 13:45
    关注

    望采纳!!点击该回答右侧的“采纳”按钮即可采纳!!

    你的代码中似乎并没有明显的语法错误。不过,有几点可以注意:

    在排序函数 none 中,应该将 a.jj<b.jj 改为 a.jj>b.jj。因为您想要将结构体数组 a 按照获奖基金的降序排序。

    在输出最高获奖基金的结构体的信息时,应该先输出 a[0].name,再输出 a[0].jj。

    在主函数 main 中,应该在循环体末尾添加一个大括号,否则会导致代码不能正常编译。

    #include<bits/stdc++.h>
    using namespace std;
    struct node{
        string name;
        int qmcj,bjcj,lw,jj;
        char gb,xb;
    }a[1000];
    bool none(node a,node b)
    {
        if(a.jj>b.jj)return 0;
        else return 1;
    }
    int nome(node a)
    {
        int sum=0;
        if(a.qmcj>80&&a.lw>0)sum+=8000;
        if(a.qmcj>85&&a.bjcj>80)sum+=4000;
        if(a.qmcj>90)sum+=2000;
        if(a.qmcj>85&&a.xb=='Y')sum+=1000;
        if(a.bjcj>80&&a.gb=='Y')sum+=850;
        return sum;
    }
    int main()
    {
        int n,sum=0;
        cin>>n;
        for(int i=0;i<n;i++)
        {
            cin>>a[i].name>>a[i].qmcj>>a[i].bjcj>>a[i].gb>>a[i].xb>>a[i].lw;
            a[i].jj=nome(a[i]);
        }
        sort(a,a+n,none);
        cout<<a[0].name<<endl<<a[0].jj<<endl;
        for(int i=0;i<n;i++)
        {
            sum+=a[i].jj;
        }
        cout<<sum;
        return 0;
    }
    
    
    
    评论

报告相同问题?

问题事件

  • 已结题 (查看结题原因) 9月22日
  • 创建了问题 12月31日

悬赏问题

  • ¥20 Java-Oj-桌布的计算
  • ¥15 请问如何在openpcdet上对KITTI数据集的测试集进行结果评估?
  • ¥15 powerbuilder中的datawindow数据整合到新的DataWindow
  • ¥20 有人知道这种图怎么画吗?
  • ¥15 pyqt6如何引用qrc文件加载里面的的资源
  • ¥15 安卓JNI项目使用lua上的问题
  • ¥20 RL+GNN解决人员排班问题时梯度消失
  • ¥60 要数控稳压电源测试数据
  • ¥15 能帮我写下这个编程吗
  • ¥15 ikuai客户端l2tp协议链接报终止15信号和无法将p.p.p6转换为我的l2tp线路