• 学生成绩管理


    有N个学生,每个学生的数据包括学号、班级、姓名、三门课成绩。从键盘输入N 个
    学生数据,要求打印出每个学生三门课的平均成绩,以及平均分最高分学生数据(包括学号、
    班级、姓名、三门课成绩,平均分)。
    要求:
    1、 定义学生结构体。
    2、 用一个函数实现N 个学生数据的输入,用另一个函数负责求每个学生三门课程的平
    均成绩,再用一个函数求出平均分最高的学生并输出该学生的数据。要求平均分和平均分最
    高的学生数据都在主函数中输出。

    输入

    第一行:N,表示N 个学生

    下面N 行:每行数据包括学号、班级、姓名、三门课成绩。

    输出

    输出每个学生三门课的平均成绩,以及平均分最高分学生数据(包括学号、班级、姓名、
    三门课成绩,平均分)。
    格式见下。(四舍五入保留一位小数)

    样例输入

    4
    20070008 software1 wangjun 87 84 76
    20070001 science1 lanxin 90 84 83
    20070007 software2 wuke 94 87 86
    20070003 science4 xuede 90 86 87

    样例输出

    wangjun 82.3
    lanxin 85.7
    wuke 89.0
    xuede 87.7
    20070007 software2 wuke 94.0 87.0 86.0 89.0
    #include<iostream>
    #include<string>
    #include<iomanip>
    using namespace std;
    struct student {
        string number;
        string clas;
        string name;
        double k1, k2, k3, aver;
    };
    void print(student s)
    {
        cout << setiosflags(ios::fixed) << setprecision(1) << s.number << " ";
        cout << setiosflags(ios::fixed) << setprecision(1) << s.clas << " ";
        cout << setiosflags(ios::fixed) << setprecision(1) << s.name << " ";
        cout << setiosflags(ios::fixed) << setprecision(1) << s.k1 << " ";
        cout << setiosflags(ios::fixed) << setprecision(1) << s.k2 << " ";
        cout << setiosflags(ios::fixed) << setprecision(1) << s.k3 << " ";
        cout << setiosflags(ios::fixed) << setprecision(1) << s.aver << endl;
    }
    void print2(student s)
    {
        cout << setiosflags(ios::fixed) << setprecision(1) << s.name << " ";
        cout << setiosflags(ios::fixed) << setprecision(1) << s.aver << "
    ";
    }
    int main()
    {
        int n;
        cin >> n;
        student s[100];
        for (int i = 0; i < n; i++)
        {
            cin >> s[i].number;
            cin >> s[i].clas;
            cin >> s[i].name;
            cin >> s[i].k1;
            cin >> s[i].k2;
            cin >> s[i].k3;
            s[i].aver = (s[i].k1 + s[i].k2 + s[i].k3) / 3;
        }
        double max = s[0].aver;
        int k = 0;
        for (int i = 0; i < n; i++)
        {
            print2(s[i]);
            if (s[i].aver > max)
            {
                max = s[i].aver;
                k = i;
            }
        }
        print(s[k]);
        system("PAUSE");
        return 0;
    }
  • 相关阅读:
    编译 | 更新标准库_交叉编译工具链
    论文 | 图文_学科
    编码 | 二进制格式设计方案
    图片 | 图片上传管理
    进程 | 查询进程中包含多少线程
    第二周02:Fusion ICP逐帧融合
    exe文件当前目录搜索文件
    第一周:读取XML深度数据并将其重建为三维点云
    第二周:01 ICP迭代交互
    C++文件读写(转载)
  • 原文地址:https://www.cnblogs.com/Lazy-Cat/p/9838376.html
Copyright © 2020-2023  润新知