c++拷贝与替换算法

一:

copy 算法是 C++ STL 中的一个常用算法,用于将一个范围内的元素复制到另一个范围。它的函数原型如下:

template<class InputIt, class OutputIt> OutputIt copy(InputIt first, InputIt last, OutputIt d_first);

这个算法接受三个参数:

  • firstlast 是输入范围的迭代器,表示要复制的元素范围。first 指向要复制的第一个元素,last 指向要复制的最后一个元素的下一个位置。
  • d_first 是输出范围的迭代器,表示复制的目标位置。复制的元素将从 d_first 开始,覆盖原有的元素,直到复制完所有的元素。

std::copy 算法会将输入范围 [first, last) 中的元素复制到输出范围 [d_first, d_first + (last - first)) 中。它会返回一个迭代器,指向复制的范围的下一个位置,即 d_first + (last - first)

cpp 复制代码
void test01()
{
	vector<int>v = { 1,2,5,3,2 };
	vector<int>v2;
	v2.resize(v.size());
		copy(v.begin(), v.end(), v2.begin());
		for_each(v2.begin(), v2.end(), [](int val)->void {cout << val << " "; });
}

二:

replace 算法是 C++ STL 中的一个常用算法,用于替换容器中的所有匹配元素。它的函数原型如下:

template<class ForwardIt, class T> void replace(ForwardIt first, ForwardIt last, const T& old_value, const T& new_value);

这个算法接受四个参数:

  • firstlast 是容器中的迭代器,表示要替换的元素范围。first 指向要替换的第一个元素,last 指向要替换的最后一个元素的下一个位置。
  • old_value 是要被替换的值。
  • new_value 是替换后的值。

std::replace 算法会遍历输入范围 [first, last) 中的所有元素,将与 old_value 相等的元素替换为 new_value

cpp 复制代码
struct myfunc
{
	bool operator()(int val)
	{
		return val > 3;
	}
};
void test02()
{
	vector<int>v = { 1,2,5,3,2 };
	for_each(v.begin(), v.end(), [](int val)->void {cout << val << " "; });
	cout << endl;
	replace(v.begin(), v.end(), 2, 200);
	for_each(v.begin(), v.end(), [](int val)->void {cout << val << " "; });
	replace_if(v.begin(), v.end(), myfunc(), 200);
	cout << endl;
	for_each(v.begin(), v.end(), [](int val)->void {cout << val << " "; });
}

三:

swap是 C++ STL 中的一个常用算法,用于交换两个变量的值。它的函数原型如下:

template<class T> void swap(T& a, T& b);

cpp 复制代码
void test03()
{
	vector<int>v{ 1,2,3,4 };
	vector<int>v1{6, 7, 8, 9};
	swap(v, v1);
	for_each(v.begin(), v.end(), [](int val)->void {cout << val << " "; });
	cout << endl;
	for_each(v1.begin(), v1.end(), [](int val)->void {cout << val << " "; });
	cout << endl;
}
相关推荐
Maple_land39 分钟前
Linux复习:系统调用与fork
linux·运维·服务器·c++·centos
墨雪不会编程42 分钟前
C++的基础语法篇一 ——命名空间
开发语言·c++
火山上的企鹅44 分钟前
Qt C++ 软件开发工程师面试题
c++·qt·面试
少许极端1 小时前
算法奇妙屋(十)-队列+宽搜(BFS)
java·数据结构·算法·bfs·宽度优先·队列
沐怡旸1 小时前
【穿越Effective C++】条款16:成对使用new和delete时要采用相同形式——内存管理的精确匹配原则
c++·面试
z20348315202 小时前
我与C++的故事
开发语言·c++·c++40周年
异步的告白2 小时前
C语言-数据结构-1-动态数组
c语言·数据结构·c++
想唱rap3 小时前
Linux开发工具(4)
linux·运维·服务器·开发语言·算法
前端炒粉3 小时前
21.搜索二维矩阵 II
前端·javascript·算法·矩阵