C++ Primer(第五版) 10.4.1--10.4.2节练习

10.26    back_inserter:创建一个使用push_back的迭代器                                                                                                                                 front_inserter:创建一个使用push_front的迭代器                                                                                                                                 inserter:创建一个使用Insert的迭代器,接受第二个参数,该参数必须是一个指向给定容器的迭代器,元素被插入到给定迭代器所表示的元素之前。

10.27    

#include <iostream>
#include <algorithm>
#include <vector>
#include <list>

using namespace std;

int main()
{
	vector<int> ivec = {1, 2, 2, 3, 4, 5, 5, 6};
	list<int> ilist;

	unique_copy(ivec.cbegin(), ivec.cend(), inserter(ilist, ilist.begin()));

	for (auto i : ilist)
		cout << i << " ";

	cout << endl;

	return 0;
}

10.28    

#include <iostream>
#include <algorithm>
#include <vector>
#include <list>

using namespace std;

int main()
{
	vector<int> ivec = {1, 2, 3, 4, 5, 6, 7, 8, 9};
	list<int> ils1, ils2, ils3;

	unique_copy(ivec.cbegin(), ivec.cend(), back_inserter(ils1));
	for (auto i : ils1)
		cout << i << " ";
	cout << endl;

	unique_copy(ivec.cbegin(), ivec.cend(), front_inserter(ils2));
	for (auto i : ils2)
		cout << i << " ";
	cout << endl;
	
	unique_copy(ivec.cbegin(), ivec.cend(), inserter(ils3, ils3.begin()));
	for (auto i : ils3)
		cout << i << " ";
	cout << endl;

	return 0;
}

10.29    

#include <iostream>
#include <algorithm>
#include <vector>
#include <fstream>
#include <iterator>

using namespace std;

int main(int argc, char *argv[])
{
	vector<string> text;

	ifstream in(argv[1]);
	istream_iterator<string> in_iter(in), end;
	
	while (in_iter != end) {
		text.push_back(*in_iter++);
	}	

	for (auto s : text)
		cout << s << " ";
	cout << endl;

	return 0;
}

10.30    

#include <iostream>
#include <iterator>
#include <vector>
#include <algorithm>

using namespace std;

int main()
{
	vector<int> ivec;

	istream_iterator<int> in_iter(cin), end;
	ostream_iterator<int> out_iter(cout, " ");

	while (in_iter != end)
		ivec.push_back(*in_iter++);
	
	sort(ivec.begin(), ivec.end());

	copy(ivec.cbegin(), ivec.cend(), out_iter);
	cout << endl;

	return 0;		

}

10.31 将上题种的copy改成unique_copy即可。

10.32 

#include <algorithm>
#include <iterator>
#include "Sales_data.h"

using namespace std;

int main()
{
	vector<Sales_data> record;
	istream_iterator<Sales_data> in_iter(cin), end;
	ostream_iterator<Sales_data> out_iter(cout, "\n");

	while (in_iter != end)
		record.push_back(*in_iter++);
	
	sort(record.begin(), record.end(), compareIsbn);
	
	auto beg = record.begin();
	
	while (beg != record.end()) {
		auto item = *beg;
		auto r = find_if(beg + 1, record.end(), 
						[item](const Sales_data &item1) { return item1.isbn() != item.isbn(); });
		auto sum = accumulate(beg + 1, r, item);
		*out_iter++ = sum;
		
		beg = r;
	}
	
	return 0;
}

10.33 

#include <iostream>
#include <fstream>
#include <iterator>

using namespace std;

int main(int argc, char *argv[])
{
	ifstream in(argv[1]);
	ofstream odd(argv[2]), even(argv[3]);
	istream_iterator<int> in_iter(in), end;
	ostream_iterator<int> odd_iter(odd, " "), even_iter(even, "\n");

	while (in_iter != end) {
		if (*in_iter % 2 == 0)
			*even_iter++ = *in_iter;
		else
			*odd_iter++ = *in_iter;
		++in_iter;
	}

	return 0;
}

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值