STL案例 评委打分

案例描述: 
有5名选手:选手ABCDE,10个评委分别对每一名选手打分,去除最高分,去除评委中最低分,取平均分
实现步骤
1. 创建五名选手,放到vector中
2. 遍历vector容器,取出来每一个选手,执行for循环,可以把10个评分打分存到deque容器中
3. sort算法对deque容器中分数排序,去除最高和最低分
4. deque容器遍历一遍,累加总分
5. 获取平均分

#include <iostream>
#include<vector>
#include<algorithm>//算法 头文件
#include<string>
#include<deque>
#include<ctime>
using namespace std;
//案例描述: 
//有5名选手:选手ABCDE,10个评委分别对每一名选手打分,去除最高分,去除评委中最低分,取平均分
// 实现步骤
//1. 创建五名选手,放到vector中
//2. 遍历vector容器,取出来每一个选手,执行for循环,可以把10个评分打分存到deque容器中
//3. sort算法对deque容器中分数排序,去除最高和最低分
//4. deque容器遍历一遍,累加总分
//5. 获取平均分

//选手类 
class Person{
	public:
		Person(string name,int score){
			this->m_Name=name;
			this->m_Score=score; 
		} 
		string m_Name;//姓名 
		int m_Score;
};
void createPerson(vector<Person>&v){
	string nameSeed="ABCDE";
	for(int i=0;i<5;i++){
		string name="选手"; 
		name+=nameSeed [i];//小技巧
		
		int score=0;
		Person p(name,score);//在这不处理分数的原因是想在deque容器中处理 
		
		//将创建的person对象 放入到容器中 
		v.push_back(p); 
	}
}
//打分 
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;
			d.push_back(score);
		}
		
//测试代码 
		cout<<"选手:"<<it->m_Name<<"打分"<<endl;
		for(deque<int>::iterator dit=d.begin();dit!=d.end();dit++){
			cout<<*dit<<" ";//10列 
		} 
		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; 
	}
}

void showScore(vector<Person>&v){
	for(vector<Person>::iterator it=v.begin();it!=v.end();it++){
		cout<<"姓名"<<it->m_Name<<"平均分:"<<it->m_Score<<endl;
	}
}
void test01(){
	//1.创建五名选手 
	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.给五名选手打分 
	setScore(v);
//	3.显示最后得分
	showScore(v); 
	

	
		
} 
int main()
{
	//随机种子
	srand((unsigned int)time(NULL)); 
	test01();
	system("pause");
}

注意看注释

相关推荐

  1. STL案例 评委打分

    2024-02-09 14:58:01       54 阅读
  2. stl写一个自动打分比赛的案例

    2024-02-09 14:58:01       53 阅读
  3. Sqlserver数据库触发器sql案例

    2024-02-09 14:58:01       63 阅读
  4. 执行SQL分析打印

    2024-02-09 14:58:01       34 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-02-09 14:58:01       94 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-02-09 14:58:01       100 阅读
  3. 在Django里面运行非项目文件

    2024-02-09 14:58:01       82 阅读
  4. Python语言-面向对象

    2024-02-09 14:58:01       91 阅读

热门阅读

  1. Python(22)正则表达式中的“限定符”

    2024-02-09 14:58:01       45 阅读
  2. C语言之扫描字符串

    2024-02-09 14:58:01       52 阅读
  3. Kubernetes的有状态应用示例:ZooKeeper

    2024-02-09 14:58:01       38 阅读
  4. JVM体系

    2024-02-09 14:58:01       55 阅读
  5. c语言_实现类class的功能 实例

    2024-02-09 14:58:01       54 阅读
  6. 贪心_分类讨论_边界问题_1921_C. Sending Messages

    2024-02-09 14:58:01       48 阅读
  7. c实现链表

    2024-02-09 14:58:01       41 阅读
  8. deepin20.9安装及配置

    2024-02-09 14:58:01       46 阅读
  9. 高精度加法 取余 分类讨论 AcWing 791. 高精度加法

    2024-02-09 14:58:01       48 阅读
  10. 【LeetCode每日一题】1122. 数组的相对排序

    2024-02-09 14:58:01       54 阅读