文章目录
前言
最近学了C++的各种容器,string容器、vector容器、deque容器等。在学习视频中正好有一个案例(评委打分)。很好的使用了这几种容器完成了评委打分求平均值的任务。我觉得很不错,就记录一下吧。
一、代码实现任务
任务要求:使用C++编写程序完成,在一个比赛中有N名参赛选手(以5名为例),选手ABCDEF,十个评委分别对每一名选手打分,去掉最高分,去掉评委中最低分,取平均成绩,给每位选手打分。
二、实现步骤
1.写一个Person类存放姓名和平均分
代码如下(示例):
class Person
{
public:
Person(string name,int score)
{
this->m_Name=name;
this->m_Score=score;
}
string m_Name; //姓名
int m_Score; //平均分
};
2.创建存放选手空的vector容器
代码如下(示例):
void createPerson(vector<Person>&v)
{
string nameSeed="ABCDE";
for(int i=0;i<5;i++)
{
string name="选手";
name+=nameSeed[i];// +=依此遍历进行nameSeed的输出
int score=0;
Person p(name,score);
//将创建的person对象,放入到容器中
v.push_back(p); //push_back进行尾插
}
}
3.打分-deque容器适合做排序操作,所以利用deque容器来进行打分的操作
void setScore(vector<Person>&v)
{
for(vector<Person>::iterator it =v.begin();it!=v.end();it++)
{
//将评委的分数 放入到deque容器中
deque<int>d;
for(int i=0;i<10;i++)
{
int score=rand()%41+60; //60~100
d.push_back(score);
}
/*cout<<"选手:"<<it->m_Name<<"打分:"<<endl;
for(deque<int>::iterator dit=d.begin();dit!=d.end();dit++)
{
cout<<*dit<<" ";
}
cout<<endl;*/
//排序
sort(d.begin(),d.end());//需要包含标准算法头文件
//去除最高和最低分
d.pop_back();
d.pop_front();
//取平均分
int sum=0;
for(deque<int>::iterator dit =d.begin();dit!=d.end();dit++)
{
sum+=*dit;//累加每个评委的分数
}
int avg =sum /d.size();
//将平均分赋值到选手身上
it->m_Score=avg;
}
}
4.写一个showScore的显示函数
void showScore(vector<Person>&v)
{
for(vector<Person>::iterator it =v.begin();it!=v.end();it++)
{
cout<<"姓名:"<<it->m_Name<<"平均分:"<<it->m_Score<<endl;
}
}
5.程序所包含的头文件
#include<iostream>
using namespace std;
#include<vector>
#include<string>
#include<deque>
#include<algorithm>
#include<ctime>
6.程序主函数的调用
int main()
{
//随机数种子
srand((unsigned int)time(NULL));
//1、创建5名选手
vector<Person>v; //存放选手容器
createPerson(v);
//测试
/*for(vector<Person>::iterator it =v.begin();it!=v.end();it++)
{
cout<<"姓名:"<<(*it).m_Name<<"分数:"<<(*it).m_Score<<endl;
}*/
//2、给5名选手打分
setScore(v);
//3、显示最后得分
showScore(v);
system("pause");
return 0;
}
总结
以上就是程序的内容,这个评委打分程序用到了vector容器来选手的姓名、成绩等信息,利用deque容器来更便捷的实现评委打分的排序,较好的计算平均成绩,利用algorithm来进行sort的分类排序,用ctime来实现随机数种子。
最近这段时间学到的东西,很好的在这个程序中体现了出来,能够综合利用的这些并且实现这个具体案例的实现,我觉得学到许多,重要的是将这些分散的知识给总结起来,真是很美妙的感觉o( ̄▽ ̄)ブ