• 学生成绩管理


    有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;
    }
  • 相关阅读:
    [Operate System & Algorithm] 页面置换算法
    [Network] 计算机网络基础知识总结
    [Search Engine] 搜索引擎技术之网络爬虫
    [Search Engine] 搜索引擎分类和基础架构概述
    [Math] 常见的几种最优化方法
    磁盘告警之---神奇的魔法(Sparse file)
    Kubernetes概念之RC
    Kubernetes概念之mater、node
    Centos7允许使用密码登录
    安装gcc-c++报错解决办法
  • 原文地址:https://www.cnblogs.com/Lazy-Cat/p/9838376.html
Copyright © 2020-2023  润新知