STL10-deque容器

本文详细介绍了C++ STL中的deque双端队列容器的基本使用方法,包括初始化、赋值、大小调整、插入和删除等操作,并通过实例展示了如何利用deque进行评分统计。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

deque 双端队列

 

deque 删除操作

deque案例:

#if 1
#include<iostream>
#include<deque>
using namespace std;
void PrintDeque(deque<int>& d) {
	for (deque<int>::iterator it = d.begin(); it != d.end(); it++) {
		cout << *it << " ";
	}
	cout << endl;
}
//deque初始化
void test01() {
	deque<int> d;
	deque<int> d2(10, 5);
	deque<int> d3(d2.begin(), d2.end());
	deque<int> d4(d3);
	//打印
	PrintDeque(d4);
}
/*
输出:
5 5 5 5 5 5 5 5 5 5
*/

//赋值 大小操作
void test02() {
	deque<int> d1;
	deque<int> d2,d3,d4;
	d1.assign(10, 5);
	d4.assign(10, 4);
	d2.assign(d1.begin(), d1.end()); //迭代器指定区间赋值
	d3 = d2; //等号赋值
	cout << "未交换前的d1和d4:" << endl;
	PrintDeque(d1);
	PrintDeque(d4);
	swap(d1, d4);
	cout << "交换后的d1和d4:" << endl;
	PrintDeque(d1);
	PrintDeque(d4);

	if (d1.empty())
		cout << "d1 is empty!" << endl;
	else
		cout << "d1 is not empty!" << endl;
	d1.resize(5);  //后5个元素扔掉
	PrintDeque(d1);
	d1.resize(8);  //以默认值填充新位置
	PrintDeque(d1);
	d1.resize(10, 88);  //容器变长,以88进行填充
	PrintDeque(d1);

}
/*
输出:
未交换前的d1和d4:
5 5 5 5 5 5 5 5 5 5
4 4 4 4 4 4 4 4 4 4
交换后的d1和d4:
4 4 4 4 4 4 4 4 4 4
5 5 5 5 5 5 5 5 5 5
d1 is not empty!
4 4 4 4 4
4 4 4 4 4 0 0 0
4 4 4 4 4 0 0 0 88 88
*/
//deque插入和删除
void test03() {
	deque<int> d1;
	d1.push_back(100);
	d1.push_front(200);
	d1.push_back(300);
	d1.push_back(400);
	d1.push_front(500);
	PrintDeque(d1);
	d1.pop_back();
	d1.pop_front();
	PrintDeque(d1);
}
/*
输出:
500 200 100 300 400
200 100 300
*/
int main()
{
	cout<<"test01" << endl;
	test01();
	cout << "test02" << endl;
	test02();
	cout << "test03" << endl;
	test03();
}
#endif

打分案例:


#include<iostream>
#include<vector>
#include<deque>
#include<algorithm>
#include<string>
using namespace std;
//评委打分案例(sort)
//创建5个选手,姓名,得分 10个评委对5个选手打分
//得分规则:去除最低分,去除最高分 去除平均分
//按得分对5名选手排名
#if 0  
//我的思路
typedef struct Person {
public:
	Person(double Score,char* Name):score(Score),name(Name){}
public:
	double score;
	char* name;
};
int main() {
	Person p1(0, "wang");
	Person p2(0, "yu");
	Person p3(0, "da");
	Person p4(0, "zhao");
	Person p5(0, "liu");
	vector<Person> v;
	v.push_back(p1);
	v.push_back(p2);
	v.push_back(p3);
	v.push_back(p4);
	v.push_back(p5);
	for (vector<Person>::iterator it = v.begin(); it != v.end(); it++) {
		cout << "请输入对" << (*it).name << "的打分:" << endl;
		deque<double> d;
		for (int i = 0; i < 10; i++)
		{
			while (cin.get() != EOF)  //错误
			{
				d.push_back(cin.get());
			}
		}
		//排序 去除左右两端 然后去平均数 然后赋值给此选手的score 用map<Person,score>进行排序
	}
	return 0;
}
#endif

#if 1
class Player {
public:
	Player(){}
	Player(double Score, string Name) :score(Score), name(Name) {}
public:
	double score;
	string name;
};
//创建选手
void Create_Player(vector<Player>& v) {
	string nameSpeed = "ABCDE";
	for (int i = 0; i < 5; i++)
	{
		Player p;
		p.name = "选手";
		p.name += nameSpeed[i];
		p.score = 0;
		v.push_back(p);
	}
	
}
void PrintdScore(int val) {
	cout << val << " ";
}
//打分
void set_Score(vector<Player>& v){
	for (vector<Player>::iterator it = v.begin(); it != v.end(); it++) {
		string name=(*it).name;
		//当前学生进行打分
		deque<int> dScore;
		for (int i = 0; i < 10; i++)
		{
			int score = rand() % 41 + 60;
			dScore.push_back(score);
		}
		sort(dScore.begin(), dScore.end());  //默认从小到大
		for_each(dScore.begin(), dScore.end(), PrintdScore);
		cout << endl;
		//去除最高分 最低分
		dScore.pop_front();
		dScore.pop_back();

		//求平均分
		int totalScore = 0;
		for (deque<int>::iterator itt = dScore.begin(); itt != dScore.end(); itt++) {
				totalScore += (*itt);
		}
		int averageScore = totalScore / dScore.size();

		//保存分数
		(*it).score = averageScore;
	}
		
}
//排序规则
bool mycompare(Player p1, Player p2) {
	return p1.score > p2.score;
}
//排名 sort默认从小到大 希望从打到小
void Print_Rank(vector<Player>& v) {
	//排序
	sort(v.begin(), v.end(), mycompare);
	//打印
	for (vector<Player>::iterator it = v.begin(); it != v.end(); it++) {
		cout << "姓名:"<<(*it).name <<"得分:"<<(*it).score<< endl;
	}
}
int main() {
	vector<Player> vPlist;
	Create_Player(vPlist);
	set_Score(vPlist);
	Print_Rank(vPlist);
	return 0;
}
#endif

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

chde2Wang

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值