C++ Primer(第五版) 9.3.1节练习

本节讨论了C++ Primer第五版中关于容器使用的一些练习,包括9.18、9.19、9.20、9.21和9.22题。9.19题建议使用list代替deque;9.21题指出在vector头部插入元素会导致性能下降,因为需要移动后续元素;9.22题涉及insert操作及迭代器失效的问题,解析了如何正确处理迭代器更新。

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

9.18 

#include <iostream>
#include <deque>

using namespace std;

int main()
{
	deque<string> sd;
	string s;

	while (cin >> s)
		sd.push_back(s);

	for (auto beg = sd.begin(); beg != sd.end(); beg++) 
		cout << *beg << endl;

	return 0;
}

9.19 用list代替deque即可,其他代码相同

9.20 

#include <iostream>
#include <list>
#include <deque>

using namespace std;

int main()
{
	list<int> ilist = {1, 2, 3, 4, 5, 6, 7, 8};
	deque<int> odd, even;

	for (auto iter = ilist.begin(); iter != ilist.end(); iter++) {
		if (*iter%2 == 0)
			odd.push_back(*iter);
		else
			even.push_back(*iter);
	}

	for (auto i : odd)
		cout << i << endl;
	for (auto j : even)
		cout << j << endl;

	return 0;

}

9.21 循环每次将元素插入vector的首前位置,iter始终指向vector首,功能和list版本一样,但vector每次在头部插入新元素都要移动后面的所有元素,性能比较差。

9.22 insert操作会使当前容器的迭代器失效,所以每次都要重新计算iter和mid,insert操作返回指向第一个新加入元素的迭代器,利用它来更新iter和mid,测试代码如下:到达中间位置以前,每次遇到5,则在其前面插入一个10

#include <iostream>
#include <vector>

using namespace std;

int main()
{
	vector<int> iv = {5, 5, 5, 5, 5};
	int someval = 5;

	vector<int>::iterator iter = iv.begin(), mid = iv.begin() + iv.size()/2;
	
	while (iter != mid) {
		auto diff = mid - iter;
		if (*iter == someval) {
			iter = iv.insert(iter, 2 * someval);
			iter += 2;
			mid = --diff + iter;
		}
	}

	for (auto i : iv)
		cout << i << endl;
	
	return 0;
}

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值