实验要求:输入30个学生的学号、姓名和5门课程的成绩,计算总分并按照总分排出名次,最后按照学号顺序打印成绩单, 并把成绩单输出为excel文件。

txt数据:

2015020981 甲 90 89 99 88 79
2015020986 戌 97 87 97 60 79
2015020970 鹏 97 88 77 80 79
2015020983 丙 92 89 70 88 79
2015020984 丁 93 84 96 36 77
2015020982 乙 61 88 99 84 70
2015020985 戊 94 81 94 82 75
2015020989 三 93 89 99 88 50
2015020994 八 91 88 49 84 70
2015020987 一 99 89 99 88 60
2015020988 二 91 58 69 84 70
2015020969 将 94 51 94 82 75
2015020960 孙 91 88 99 84 99
2015020990 四 93 84 96 86 77
2015020995 九 92 50 99 88 79
2015020992 六 97 87 97 80 79
2015020993 七 90 69 99 88 79
2015020997 张 74 81 54 82 75
2015020996 十 63 84 96 86 77
2015020965 郑 90 88 99 88 79
2015020998 王 97 87 100 80 79
2015020999 李 40 89 99 88 79
2015020963 刘 94 89 94 82 75
2015020961 赵 92 89 99 88 79
2015020962 岳 93 84 96 86 100
2015020966 林 51 88 99 84 70
2015020964 宋 97 87 47 80 79
2015020968 宗 93 84 96 86 57
2015020967 任 92 89 99 70 79
2015020991 五 94 81 44 82 75

源代码:

#include<iostream>
#include<cstdio>
#include<fstream>
#include<string>
#include<algorithm>
using namespace std;
struct Student
{

int id;
    string name;
    int score[5];
    int total;
    int rank;
public:
    friend ostream & operator<<(ostream & out, const Student &stu);
    friend istream & operator>>(istream & in, Student &stu);
};
ostream & operator <<(ostream & out, const Student &stu)
{
    out << stu.id<<"\t"<<stu.name << "\t" << stu.score[0]<<"\t"<< stu.score[1]
        <<"\t" << stu.score[2]<<"\t"<< stu.score[3]<<"\t" << stu.score[4] <<"\t"
        <<stu.total<<"\t"<<stu.rank<<endl ;
    return out;
}
istream & operator >>(istream & in,  Student &stu)
{
    in>>stu.id>>stu.name >> stu.score[0]>> stu.score[1]>> stu.score[2]
        >> stu.score[3] >>stu.score[4];
    return in;
}
int main()
{
    string filename1;
    int num = 0;
    Student stu[100];
    int ReadTextFile(string fname, Student stu[]);//从文件中读取TXT数据
    void PrintScreen(Student stu[], int n);//打印数据在屏幕中
    void Total(Student stu[],int n);//计算总分
    void Rank(Student stu[], int n);//计算排名
    void Sort(Student stu[], int n);//按学号排序
    void WExcel(Student stu[], int n);//在Excel中输出
    filename1 = "c:\\score.txt";
    num=ReadTextFile(filename1, stu);
    Total(stu,num);
    Rank(stu, num);
    Sort(stu, num);
    WExcel(stu, num);
    PrintScreen(stu, num); 
}

//从文件中读取TXT数据
int ReadTextFile(string fname, Student stu[])
{
    int i = 0;
    ifstream fin(fname);
    if (!fin)
    {
        cout << "source text file error\n";
        return 0;
    }
    fin >> stu[i];
    while (!fin.eof())
    {
        i++;
        fin >> stu[i];
    }
    fin.close(); 
    return i;
}

//打印数据在屏幕中
void PrintScreen(Student stu[], int n)
{
    for (int i = 0; i <n; i++)
        cout << stu[i];
}
void Total(Student stu[],int n)
{
    for (int i=0; i < n; i++)
    {
        stu[i].total= stu[i].score[0] + stu[i].score[1] + stu[i].score[2]
            + stu[i].score[3] + stu[i].score[4];
    }
}

//计算总分
void Rank(Student stu[], int n)
{
    int temp,i,j;
    for ( i = 0; i < n; i++)
    {
        temp = 0;
        {for (j = 0; j < n; j++)
            if (stu[i].total<=stu[j].total)
                temp++;
        stu[i].rank = temp;
        }
    }
}

//按学号排序
void Sort(Student stu[],int n)
{
    int i, j;
    Student temp;
    for(i=0;i<n;i++)
        for(j=i+1;j<n;j++)
            if (stu[i].id>stu[j].id)
            {
                temp = stu[i];
                stu[i] = stu[j];
                stu[j] = temp;
            }
}

//在Excel中输出
void WExcel(Student stu[], int n)
{
    ofstream oFile;
    oFile.open("1.csv", ios::out | ios::trunc);
    oFile << "学号"<<"," << "姓名" << "," << "成绩1" << "," << "成绩2" 
        << ","<<"成绩3"<<"," << "成绩4"<<" ,"<< "成绩5"<<","
        <<"总分"<<","<<"排名"<<endl;
    for (int i = 0; i < n; i++)
    {
        oFile << stu[i].id << "," << stu[i].name << "," << stu[i].score[0] 
            << "," << stu[i].score[1]<< "," << stu[i].score[2] << "," 
            << stu[i].score[3] << "," << stu[i].score[4]<<","<<stu[i].total
            <<","<<stu[i].rank<<endl;
    }
    oFile.close();
}

学生成绩管理系统: 统计成绩排序并打印(c++)(内含读取文件.txt及将文件输出excel的方法)的更多相关文章

  1. 【转】 [C/OC的那点事儿]NSMutableArray排序的三种实现(依赖学生成绩管理系统).

    原文网址:http://blog.csdn.net/ministarler/article/details/17018839 c语言实现的学生成绩管理系统是面向过程的,而OC实现的学生成绩管理系统则是 ...

  2. c++链表实现学生成绩管理系统(简易版)

    #include<iostream> using namespace std; typedef struct student{ int id;//学号 string sex; string ...

  3. 学生成绩管理系统C(链表)语言

    #include"stdio.h" #include"stdlib.h" #include"string.h" //用于调用一些函数 str ...

  4. 学生成绩管理系统[C]

    #include<stdio.h> #include<stdlib.h> #include<string.h> #include<conio.h> #d ...

  5. 使用C++名单在文档处理和学生成绩管理系统相结合

    对于学生成绩管理系统,我并不陌生,几乎学习C人的语言.做项目会想到学生成绩管理系统,我也不例外.在研究中的一段时间C语言之后,还用C语言到学生管理系统,然后做几个链接.计数,这个系统是以前的系统上的改 ...

  6. 【学生成绩管理系统】 大二c语言作业

    几年前写的了,只能在命令行窗口运行,虽然比较挫,还是有一定参考价值... #include <cstdio> #include <conio.h> #include <i ...

  7. [项目记录] 用c语言完成的一个学生成绩管理系统

    一.要求: 学生成绩管理系统 某班有最多不超过30人(具体人数由键盘输入)参加期末考试,最多不超过6门(具体门数由键盘输入).使用链表编程实现如下菜单驱动的学生成绩管理系统. 从文件读入每个学生个人信 ...

  8. 学生成绩管理系统C++

    今天晚上终于做完了学生成绩管理系统!激动!开心!!!哈哈哈~~~~ 总共298行代码,第一次写这么多. 其中遇到了好多困难,也烦恼了好久,不过最终都解决了! 做了之后果然,满满的成就感!抑制不住的兴奋 ...

  9. C语言项目:学生成绩管理系统

    C语言项目:学生成绩管理系统    1.数据结构:学生信息:学号.姓名.年龄.性别.3课成绩    2.功能:   (1)增加学生记录    (2)  删除学生记录    (3)  查找学生信息(学号 ...

随机推荐

  1. Gif开发笔记(一):gif介绍、编译和工程模板

      前言   实现gif图片的解码和生成.   Gif 简介   GIF格式的名称是Graphics Interchange Format的缩写,是在1987年由Compu Serve公司为了填补跨平 ...

  2. 【面试】关于get和post两种方法的不同。

    最近在面试题和笔试题中经常会看到这道题,所以打算系统的整理一下. 一般标准的答案是这样的. GET在浏览器回退时是无害的,而POST会再次提交请求(浏览器应该告知用户数据会被重新提交). GET产生的 ...

  3. CSS基础-链接

    链接的状态 link 没有访问过的 visited 访问过的 hover 用户鼠标刚好停留在这个链接上时 focus 通过TAB键或者编程方法将一个链接选中时 active 链接被激活时   默认的链 ...

  4. 一份平民化的MySQL性能优化指南

    前言 近期在重新学习总结MySQL数据库性能优化的相关知识,本文是根据自己学习以及日常性能测试调优过程中总结的经验整理了一份平民化的优化指南,希望对大家在进行MySQL调优分析时有帮助!   MySQ ...

  5. TMOOC-1692-分西瓜

    题目 描述 今天是阴历七月初五,首师大附中信息社团队员GDC的生日.GDC正在和SCX.WXY在首师大附中集训.他想给这两位兄弟买点什么庆祝生日,经过调查,GDC发现SCX和WXY都很喜欢吃西瓜,而且 ...

  6. AcWing 361. 观光奶牛

    01规划 设答案为 \(ans\). 二分答案,设当前二分值为 \(mid\). 设一个环 \(S\) 的边权为 \(t_1, t_2, t_3...\),点权为 \(f_1, f_2, f_3... ...

  7. Oracle 迁移数据库到 mysql

    一. oracle导出.sql文件(Navicat Premiu  11.0.8  无法实现oracle到mysql的数据传输亲测有效) exp username/pass@数据局地址ip:1521/ ...

  8. Kubernetes K8S之鉴权RBAC详解

    Kubernetes K8S之鉴权概述与RBAC详解 K8S认证与授权 认证「Authentication」 认证有如下几种方式: 1.HTTP Token认证:通过一个Token来识别合法用户. H ...

  9. RMAN duplicate from active database

    在Oracle 11G有二种方法实现duplicate: 1.Active database duplication 2.Backup-based duplication Active databas ...

  10. ORA-28017: The password file is in the legacy format

    1.数据库升级后修改sys密码报错. 一般从oracle 从11G(11.2.0.4)升级到12C或者19C,修改SYS密码会有以下报错: ORA-28017: The password file i ...