C++STL笔记五:STL案例一。

案例描述

有5名选手:选手ABCDE,10个评委分别对每一名选手打分,去除最高分,去除评委中最低分,取平均分。

实现步骤

  1. 创建五名选手,放到vector中

  2. 遍历vector容器,取出来每一个选手,执行for循环,可以把10个评分打分存到deque容器中

  3. sort算法对deque容器中分数排序,去除最高和最低分

  4. deque容器遍历一遍,累加总分

  5. 获取平均分  

#include<iostream>
#include<deque>
#include<vector>
#include<algorithm>
using namespace std;

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>& vec)
{
	// 五个对象命名技巧。
	string nameSeed = "ABCDE";
	for (int i = 0; i < 5; i++)
	{
		string name = "选手";
		name += nameSeed[i];
		int score = 0;
		Person p(name, score);
		vec.push_back(p);
	}
}

void setScore(vector<Person>& vec)
{
	for (vector<Person>::iterator it = vec.begin(); it != vec.end(); it++)
	{
		// 因为需要删除最高分和最低分,所以需要先排序,然后将容器的头尾元素删除,
		// 涉及头部操作,所以优选deque
		deque<int> deq_score;
		for (int i = 0; i < 10; i++)
		{
			int score = rand() % 41 + 60;   // 60到100之间的数。
			deq_score.push_back(score);
		}
		// 排序,分出最大值,最小值。
		sort(deq_score.begin(), deq_score.end());
		// 删除最高分和最低分。
		deq_score.pop_front();
		deq_score.pop_back();

		// 计算平均分:
		int sum = 0;
		for (deque<int>::iterator dit = deq_score.begin(); dit != deq_score.end(); dit++)
		{
			sum += (*dit);
		}
		int ave = sum / deq_score.size();
		// 将平均值赋值给每一名选手
		it->m_Score = ave;
	}
	//sort(vec.begin(), vec.end());  // 怎么就不对了。对vec元素排序不对,需要对vec中的属性score排序。sort支持重载,有个三参数的版本,第三个参数是_Pr_Pred。回调这个函数。
}

void showScore(const vector<Person>& vec)
{
	for (vector<Person>::const_iterator cit = vec.begin(); cit != vec.end(); cit++)
	{
		cout << "姓名:" << cit->m_Name << ",得分:" << cit->m_Score << endl;
	}
}

int main()
{
	// 设置随机种子;让每一次随机都不同。
	srand((unsigned int)time(NULL));

	// 将选手放入vector中,将评委打分放入在deque中,因为需要排序后将最低分和最高分删除。这种删除头尾的操作,deque最适合。
	vector<Person> v;   // 存放选手的容器。
	// 1、创建五名选手。
	createPerson(v);

	// 2、阶段测试
	//for (vector<Person>::iterator it = v.begin(); it != v.end(); it++)
	//{
	//	cout << "姓名:" << (*it).m_Name << ",得分:" << (*it).m_Score << endl;
	//}

	// 3、打分。
	setScore(v);

	// 4、输出最后结果:
	showScore(v);

	system("pause");
	return 0;
}

注意事项:

  1. 需要去掉最高分和最低分,所有需要先排序,然后删除头尾两个元素,删除头部元素,我们优选deque。所以十个打分,我们存储在deque中,五名队员只要放在vector中即可。
  2. 对于随机数使用,设置随机数种子,可以避免每次随机数都一样。
  3. rand() % 41的取值是从0到40。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值