C++第2周项目3——用结构体数组作计算

简介: 课程首页地址:http://blog.csdn.net/sxhelijian/article/details/7910565,本周题目链接:http://blog.csdn.net/sxhelijian/article/details/8635385【项目3-用结构体数组作计算】接项目2,(1)从文件中读出数据,存放到你定义的结构体数组中,即项目2(1);(2)求出每名同学的总分(可以在读

课程首页地址:http://blog.csdn.net/sxhelijian/article/details/7910565,本周题目链接:http://blog.csdn.net/sxhelijian/article/details/8635385


【项目3-用结构体数组作计算】接项目2,
(1)从文件中读出数据,存放到你定义的结构体数组中,即项目2(1);
(2)求出每名同学的总分(可以在读入过程中“顺便”计算);
(3)按总分排序(降序);
(4)输出排序后的成绩单;
(5)有30名同学可以获得奖学金,规则是总分高者优先,有挂科不能得奖学金。请输出可以得奖学金同学的名单。
(6)选做:统计各门课及总分的平均成绩、最高和最低成绩、标准偏差,并输出。 
  建议做两个版本:(1)所有功能全在main()函数中;(2)用自定义函数实现各任务


参考解答版本(1)所有功能全在main()函数中

#include <iostream>
#include <fstream>
#include <cstdlib>  //在codeblocks下,exit(1)需要这个头文件
using namespace std;
struct Student
{
    char num[13]; //尽管都是由数字构成,但看作为字符更合适。学号12位,定义为13个字符,便于处理成字符串
    char name[10]; //每个汉字占两个字节,中国人的名字,5个汉字够用
    int cpp;
    int math;
    int english;
    int grade;
};
const int N=200;
int main( )
{
    int i, j, k, stuNum=0;
    //定义结构体数组
    Student stu[N], t_stu;

    //(1)从文件中读出数据,存放到你定义的结构体数组中;
    //(2)求出每名同学的总分(可以在读入过程中“顺便”计算);
    ifstream infile("score.txt",ios::in); 	//以输入的方式打开文件
    if(!infile)   				//测试是否成功打开
    {
        cerr<<"open error!"<<endl;
        exit(1);
    }

    i=0;
    while(!infile.eof())
    {
        infile>>stu[i].num>>stu[i].name>>stu[i].cpp>>stu[i].math>>stu[i].english;
        stu[i].grade=stu[i].cpp+stu[i].math+stu[i].english;
        ++stuNum;
        ++i;
    }
    infile.close();
    
    //(3)按总分排序(降序),用了选择排序,用冒泡腻了
    for(i=0; i<stuNum-1; i++)
    {
        k=i;
        for(j=i+1; j<stuNum; j++)
            if(stu[j].grade>stu[k].grade) k=j;  //排序的依据是总分,此for循环找出当前总分最高的学生的下标k
        t_stu=stu[k];  //交换,结构体变量可以直接赋值。当然,结构体数组元素的值可以赋值给结构体变量
        stu[k]=stu[i];
        stu[i]=t_stu;
    }

    //(4)输出排序后的成绩单;
    for(i=0; i<stuNum; ++i)
    {
        cout<<stu[i].num<<"\t"<<stu[i].name<<"\t"<<stu[i].cpp<<"\t"<<stu[i].math<<"\t"<<stu[i].english<<"\t"<<stu[i].grade<<endl;
    }

    //(5)有30名同学可以获得奖学金,规则是总分高者优先,有挂科不能得奖学金。请输出可以得奖学金同学的名单。
    //下面输出得奖学金同学的名单(貌似合理的解法)
    cout<<"恭喜以下同学获得奖学金(奖学金用于改善学习条件,杜绝请客吃饭!)"<<endl;
    i=0,j=1;
    while (j<=30)
    {
        if (stu[i].cpp>=60&&stu[i].math>=60&&stu[i].english>=60)
        {
            cout<<j<<'\t'<<stu[i].name<<'\t'<<stu[i].grade<<endl;
            j++;
        }
        i++;
    }

    //如果有人的总分与第30名相同,且没有挂科,不给他奖学金是不合理的,下面的输出弥补了这一问题,加名额吧
    //如果要采取题目中没有交待的其他办法(如抽签),作为感兴趣的扩展吧
    cout<<"恭喜以下同学获得奖学金(奖学金用于改善学习条件,杜绝请客吃饭!)"<<endl;
    i=0,j=1;
    int g;
    while (j<=30)
    {
        if (stu[i].cpp>=60&&stu[i].math>=60&&stu[i].english>=60)
        {
            cout<<j<<'\t'<<stu[i].name<<'\t'<<stu[i].grade<<endl;
            g=stu[i].grade;
            j++;
        }
        i++;
    }
    while(g==stu[i].grade)//和刚才输出的最后一个总分相同的同学都有机会获得奖学金
    {
        if (stu[i].cpp>=60&&stu[i].math>=60&&stu[i].english>=60)
        {
            cout<<j<<'\t'<<stu[i].name<<'\t'<<stu[i].grade<<endl;
            j++;
        }
        i++;
    }

    //(6)选做:统计各门课及总分的平均成绩、最高和最低成绩、标准偏差,并输出。 (这一点不做参考了,耐心做,能做出来。)

    return 0;
}

参考解答版本(2)用自定义函数实现各任务

#include <iostream>
#include <fstream>
#include <cstdlib>  //在codeblocks下,exit(1)需要这个头文件
using namespace std;
struct Student
{
    char num[13]; //尽管都是由数字构成,但看作为字符更合适。学号12位,定义为13个字符,便于处理成字符串
    char name[10]; //每个汉字占两个字节,中国人的名字,5个汉字够用
    int cpp;
    int math;
    int english;
    int grade;
};
//声明函数
int getData(Student s[]);
void outputData(Student s[],int n);
void sort(Student s[],int n);
void listScholars1(Student s[],int n);
void listScholars2(Student s[],int n);

const int N=200;
int main( )
{
    int stuNum;
    //定义结构体数组
    Student stu[N];

    //(1)从文件中读出数据,存放到你定义的结构体数组中;
    //(2)求出每名同学的总分(可以在读入过程中“顺便”计算);
    stuNum=getData(stu);

    //(3)按总分排序(降序),用了选择排序,用冒泡腻了
    sort(stu,stuNum);

    //(4)输出排序后的成绩单;
    outputData(stu,stuNum);

    //(5)有30名同学可以获得奖学金,规则是总分高者优先,有挂科不能得奖学金。请输出可以得奖学金同学的名单。
    //下面输出得奖学金同学的名单(貌似合理的解法)
    listScholars1(stu,stuNum);

    //如果有人的总分与第30名相同,且没有挂科,不给他奖学金是不合理的,下面的输出弥补了这一问题,加名额吧
    //如果要采取题目中没有交待的其他办法(如抽签),作为感兴趣的扩展吧
    listScholars2(stu,stuNum);

    //(6)选做:统计各门课及总分的平均成绩、最高和最低成绩、标准偏差,并输出。 (这一点不做参考了,耐心做,能做出来。)


    return 0;
}

//定义函数
//(1)从文件中读出数据,存放到你定义的结构体数组中;
//(2)求出每名同学的总分(可以在读入过程中“顺便”计算);
//返回值为学生人数
int getData(Student s[])
{
    ifstream infile("score.txt",ios::in); 	//以输入的方式打开文件
    if(!infile)   				//测试是否成功打开
    {
        cerr<<"open error!"<<endl;
        exit(1);
    }
    int i=0;
    while(!infile.eof())
    {
        infile>>s[i].num>>s[i].name>>s[i].cpp>>s[i].math>>s[i].english;
        s[i].grade=s[i].cpp+s[i].math+s[i].english;
        ++i;
    }
    infile.close();
    return i;  //i为学生人数
}

//(3)按总分排序(降序),用了选择排序
void sort(Student s[],int n)
{
    int i,j,k;
    Student t_stu;

    for(i=0; i<n-1; i++)
    {
        k=i;
        for(j=i+1; j<n; j++)
            if(s[j].grade>s[k].grade) k=j;  //排序的依据是总分,此for循环找出当前总分最高的学生的下标k
        t_stu=s[k];  //交换,结构体变量可以直接赋值。当然,结构体数组元素的值可以赋值给结构体变量
        s[k]=s[i];
        s[i]=t_stu;
    }
    return;
}

//(4)输出成绩单;
void outputData(Student s[],int n)
{
    for(int i=0; i<n; ++i)
    {
        cout<<s[i].num<<"\t"<<s[i].name<<"\t"<<s[i].cpp<<"\t"<<s[i].math<<"\t"<<s[i].english<<"\t"<<s[i].grade<<endl;
    }
    return;
}

//(5)有30名同学可以获得奖学金,规则是总分高者优先,有挂科不能得奖学金。
void listScholars1(Student s[],int n)
{
    cout<<"恭喜以下同学获得奖学金(奖学金用于改善学习条件,杜绝请客吃饭!)"<<endl;
    int i=0,j=1;
    while (j<=30&&j<=n)
    {
        if (s[i].cpp>=60&&s[i].math>=60&&s[i].english>=60)
        {
            cout<<j<<'\t'<<s[i].name<<'\t'<<s[i].grade<<endl;
            j++;
        }
        i++;
    }
}

//另一种奖学金规则
void listScholars2(Student s[],int n)
{
    cout<<"恭喜以下同学获得奖学金(奖学金用于改善学习条件,杜绝请客吃饭!)"<<endl;
    int i=0,j=1;
    int g;
    while (j<=30&&j<=n)
    {
        if (s[i].cpp>=60&&s[i].math>=60&&s[i].english>=60)
        {
            cout<<j<<'\t'<<s[i].name<<'\t'<<s[i].grade<<endl;
            g=s[i].grade;
            j++;
        }
        i++;
    }
    while(g==s[i].grade)//和刚才输出的最后一个总分相同的同学都有机会获得奖学金
    {
        if (s[i].cpp>=60&&s[i].math>=60&&s[i].english>=60)
        {
            cout<<j<<'\t'<<s[i].name<<'\t'<<s[i].grade<<endl;
            j++;
        }
        i++;
    }
}


目录
相关文章
|
12月前
|
搜索推荐 编译器 C语言
【C++核心】特殊的元素集合-数组与字符串详解
这篇文章详细讲解了C++中数组和字符串的基本概念、操作和应用,包括一维数组、二维数组的定义和使用,以及C风格字符串和C++字符串类的对比。
203 4
|
8月前
|
存储 算法 搜索推荐
【C++面向对象——群体类和群体数据的组织】实现含排序功能的数组类(头歌实践教学平台习题)【合集】
1. **相关排序和查找算法的原理**:介绍直接插入排序、直接选择排序、冒泡排序和顺序查找的基本原理及其实现代码。 2. **C++ 类与成员函数的定义**:讲解如何定义`Array`类,包括类的声明和实现,以及成员函数的定义与调用。 3. **数组作为类的成员变量的处理**:探讨内存管理和正确访问数组元素的方法,确保在类中正确使用动态分配的数组。 4. **函数参数传递与返回值处理**:解释排序和查找函数的参数传递方式及返回值处理,确保函数功能正确实现。 通过掌握这些知识,可以顺利地将排序和查找算法封装到`Array`类中,并进行测试验证。编程要求是在右侧编辑器补充代码以实现三种排序算法
125 5
|
8月前
|
Serverless 编译器 C++
【C++面向对象——类的多态性与虚函数】计算图像面积(头歌实践教学平台习题)【合集】
本任务要求设计一个矩形类、圆形类和图形基类,计算并输出相应图形面积。相关知识点包括纯虚函数和抽象类的使用。 **目录:** - 任务描述 - 相关知识 - 纯虚函数 - 特点 - 使用场景 - 作用 - 注意事项 - 相关概念对比 - 抽象类的使用 - 定义与概念 - 使用场景 - 编程要求 - 测试说明 - 通关代码 - 测试结果 **任务概述:** 1. **图形基类(Shape)**:包含纯虚函数 `void PrintArea()`。 2. **矩形类(Rectangle)**:继承 Shape 类,重写 `Print
129 4
WK
|
10月前
|
机器学习/深度学习 人工智能 算法
那C++适合开发哪些项目
C++ 是一种功能强大、应用广泛的编程语言,适合开发多种类型的项目。它在游戏开发、操作系统、嵌入式系统、科学计算、金融、图形图像处理、数据库管理、网络通信、人工智能、虚拟现实、航空航天等领域都有广泛应用。C++ 以其高性能、内存管理和跨平台兼容性等优势,成为众多开发者的选择。
WK
470 1
|
11月前
|
Ubuntu Linux 编译器
Linux/Ubuntu下使用VS Code配置C/C++项目环境调用OpenCV
通过以上步骤,您已经成功在Ubuntu系统下的VS Code中配置了C/C++项目环境,并能够调用OpenCV库进行开发。请确保每一步都按照您的系统实际情况进行适当调整。
1869 3
|
12月前
|
存储 算法 C++
【C++核心】结构体、共用体详解
这篇文章详细讲解了C++中结构体和共用体的概念、定义、使用场景和案例,包括结构体的创建、数组、指针、嵌套、函数参数传递,以及共用体的特点和应用实例。
171 4
|
12月前
|
C++
【C++案例】一个项目掌握C++基础-通讯录管理系统
这篇文章通过一个通讯录管理系统的C++项目案例,详细介绍了如何使用C++实现添加、显示、删除、查找、修改和清空联系人等功能。
204 3
C++(十一)对象数组
本文介绍了C++中对象数组的使用方法及其注意事项。通过示例展示了如何定义和初始化对象数组,并解释了栈对象数组与堆对象数组在初始化时的区别。重点强调了构造器设计时应考虑无参构造器的重要性,以及在需要进一步初始化的情况下采用二段式初始化策略的应用场景。
|
12月前
|
C++
继续更新完善:C++ 结构体代码转MASM32代码
继续更新完善:C++ 结构体代码转MASM32代码
|
7月前
|
编译器 C++ 开发者
【C++篇】深度解析类与对象(下)
在上一篇博客中,我们学习了C++的基础类与对象概念,包括类的定义、对象的使用和构造函数的作用。在这一篇,我们将深入探讨C++类的一些重要特性,如构造函数的高级用法、类型转换、static成员、友元、内部类、匿名对象,以及对象拷贝优化等。这些内容可以帮助你更好地理解和应用面向对象编程的核心理念,提升代码的健壮性、灵活性和可维护性。