STL常用拷贝和替换算法

简介: STL常用拷贝和替换算法

全部案例链接


https://download.csdn.net/download/weixin_45525272/12536637



常用拷贝和替换算法


copy算法 将容器内指定范围的元素拷贝到另一容器中


@param beg 容器开始迭代器
@param end 容器结束迭代器
@param dest 目标起始迭代器


copy(iterator beg, iterator end, iterator dest)


replace算法 将容器内指定范围的旧元素修改为新元素


@param beg 容器开始迭代器
@param end 容器结束迭代器
@param oldvalue 旧元素
@param oldvalue 新元素


replace(iterator beg, iterator end, oldvalue, newvalue)


replace_if算法 将容器内指定范围满足条件的元素替换为新元素


@param beg 容器开始迭代器
@param end 容器结束迭代器
@param callback函数回调或者谓词(返回Bool类型的函数对象)
@param oldvalue 新元素


replace_if(iterator beg, iterator end, _callback, newvalue)


swap算法 互换两个容器的元素


@param c1容器1
@param c2容器2


swap(container c1, container c2)


代码案例


#define _CRT_SECURE_NO_WARNINGS
#include<iostream>
#include <vector>
#include <algorithm>
#include <iterator>
using namespace std;
/*
copy算法 将容器内指定范围的元素拷贝到另一容器中
@param beg 容器开始迭代器
@param end 容器结束迭代器
@param dest 目标起始迭代器
*/
void test01()
{
  vector<int>v;
  for (int i = 0; i < 10; i++)
  {
    v.push_back(i);
  }
  vector<int>vTarget;
  vTarget.resize(v.size());
  copy(v.begin(), v.end(), vTarget.begin());
  //for_each(vTarget.begin(), vTarget.end(), [](int val){ cout << val << " "; });
  copy(vTarget.begin(), vTarget.end(), ostream_iterator<int>(cout, " "));
}
/*
replace算法 将容器内指定范围的旧元素修改为新元素
@param beg 容器开始迭代器
@param end 容器结束迭代器
@param oldvalue 旧元素
@param oldvalue 新元素
replace_if算法 将容器内指定范围满足条件的元素替换为新元素
@param beg 容器开始迭代器
@param end 容器结束迭代器
@param callback函数回调或者谓词(返回Bool类型的函数对象)
@param oldvalue 新元素
*/
class MyCompare
{
public:
  bool operator()(int v)
  {
    return v > 3;
  }
};
void test02()
{
  vector<int>v;
  for (int i = 0; i < 10; i++)
  {
    v.push_back(i);
  }
  //需求 把容器中的3  替换成300
  replace(v.begin(), v.end(), 3, 300);
  copy(v.begin(), v.end(), ostream_iterator<int>(cout, " "));
  cout << endl;
  //需求  把容器中所有大于3的数字 都替换成 30000
  replace_if(v.begin(), v.end(), MyCompare(), 30000);
  copy(v.begin(), v.end(), ostream_iterator<int>(cout, " "));
}
/*
swap算法 互换两个容器的元素
@param c1容器1
@param c2容器2
*/
void test03()
{
  vector<int>v1;
  for (int i = 0; i < 10; i++)
  {
    v1.push_back(i);
  }
  vector<int>v2;
  v2.push_back(10);
  v2.push_back(30);
  v2.push_back(20);
  v2.push_back(40);
  cout << "交换前数据:" << endl;
  copy(v1.begin(), v1.end(), ostream_iterator<int>(cout, " "));
  cout << endl;
  copy(v2.begin(), v2.end(), ostream_iterator<int>(cout, " "));
  cout << endl;
  cout << "交换后的数据:" << endl;
  swap(v1, v2);
  copy(v1.begin(), v1.end(), ostream_iterator<int>(cout, " "));
  cout << endl;
  copy(v2.begin(), v2.end(), ostream_iterator<int>(cout, " "));
  cout << endl;
}
int main(){
  //test01();
  //test02();
  test03();
  system("pause");
  return EXIT_SUCCESS;
}
相关文章
|
4月前
|
算法 数据处理 C++
c++ STL划分算法;partition()、partition_copy()、stable_partition()、partition_point()详解
这些算法是C++ STL中处理和组织数据的强大工具,能够高效地实现复杂的数据处理逻辑。理解它们的差异和应用场景,将有助于编写更加高效和清晰的C++代码。
90 0
|
8月前
|
算法 前端开发 Linux
【常用技巧】C++ STL容器操作:6种常用场景算法
STL在Linux C++中使用的非常普遍,掌握并合适的使用各种容器至关重要!
123 10
|
7月前
|
算法 C++
STL算法大全
以上只是一部分STL算法的简单概述,每一个算法都有其特定的使用场景和规则,具体使用时需要参考相关文档或者教程进行深入理解和学习。
48 0
|
7月前
|
机器学习/深度学习 算法 搜索推荐
|
9月前
|
算法 C++ 容器
黑马c++ STL常用算法 笔记(5) 常用算术生成算法
黑马c++ STL常用算法 笔记(5) 常用算术生成算法
|
9月前
|
算法 C++ 容器
黑马c++ STL常用算法 笔记(4) 常用拷贝和替换算法
黑马c++ STL常用算法 笔记(4) 常用拷贝和替换算法
|
9月前
|
存储 算法 搜索推荐
黑马c++ STL常用算法 笔记(3) 排序算法
黑马c++ STL常用算法 笔记(3) 排序算法
|
8月前
|
算法 搜索推荐 C++
C++之STL常用算法(遍历、查找、排序、拷贝、替换、算数生成、集合)
C++之STL常用算法(遍历、查找、排序、拷贝、替换、算数生成、集合)
|
9月前
|
算法 C++
c++算法学习笔记 (21) STL
c++算法学习笔记 (21) STL
|
9月前
|
算法 C++ 容器
黑马c++ STL常用算法 笔记(6) 常用集合算法
黑马c++ STL常用算法 笔记(6) 常用集合算法

热门文章

最新文章