当前位置: 首页 > article >正文

C++常用拷贝和替换算法

算法简介:

  • copy // 容器内指定的元素拷贝到另一容器
  • replace // 将容器内指定范围的旧元素改为新元素
  • replace_if // 容器内指定范围满足条件的元素替换为新元素
  • swap //互换两个容器的元素

1. copy

功能描述:

将容器内指定范围的数据拷贝到另一容器中

函数原型:

copy(iterator beg, iterator end, iterator pos);
beg 开始迭代器
end 结束迭代器
pos 插入数据的位置
// main.cpp
#include <iostream>
#include <string>
#include <vector>
#include <algorithm>
#include <functional>
using namespace std;

void test01() {
    vector<int> v;
    for (int i = 0; i < 10; i++) {
        v.push_back(i);
    }
    vector<int> v2;
    v2.resize(v.size());
    copy(v.begin(), v.end(), v2.begin());

    // 或者继续使用lambda表达式,确保编译器支持C++11及以上标准
    for_each(v2.begin(), v2.end(), [](int val) {
        cout << val << " ";
    });
    cout << endl;
}

int main() {
    test01();
    return 0;
}

2. replace

功能描述:

 将容器内指定范围的元素替换为新元素

函数原型:
void replace(iterator beg, iterator end, oldvalue, newvalue);

参数说明:

beg  开始迭代器
end  结束迭代器
oldvalue  旧元素
newvalue  新元素
#include <iostream>
#include <fstream>
#include <string>
#include <vector>
#include <functional>
#include <algorithm>
using namespace std;

// replace


void myPrint(int val){
    cout << val << " ";
}

void test01()
{
    vector<int> v;
    v.push_back(10);
    v.push_back(20);
    v.push_back(20);
    v.push_back(40);
    v.push_back(50);
    cout << "替换前:" << endl;
    for_each(v.begin(), v.end(), myPrint);
    cout << endl;

    cout << "替换后:" << endl;
    // 将容器中的20替换为2000
    replace(v.begin(), v.end(), 20, 2000);
    for_each(v.begin(), v.end(), myPrint);
    cout << endl;
}


int main(int argc, char const *argv[])
{
    test01();
    return 0;
}

3. replace_if

功能描述:

将容器中满足条件的元素替换为新的元素

函数原型:

replace(iterator beg, iterator end, _pred, newvalue);

参数说明:

beg 开始迭代器
end 结束迭代器
_pred 谓词
newvalue 替换的新元素
#include <iostream>
#include <fstream>
#include <string>
#include <vector>
#include <functional>
#include <algorithm>
using namespace std;

// replace_if


void myPrint(int val){
    cout << val << " ";
}

class MyCompare{
public:
    MyCompare(int num) : num(num){}
    bool operator()(int val){
        return val >= 20;
    }
    int num;
};

void test01()
{
    vector<int> v;
    v.push_back(10);
    v.push_back(20);
    v.push_back(20);
    v.push_back(40);
    v.push_back(50);
    cout << "替换前:" << endl;
    for_each(v.begin(), v.end(), myPrint);
    cout << endl;

    cout << "替换后:" << endl;
    // 将容器中的20替换为2000 ,可以用deepseek 查看bind2nd 含义,或者看源码
    replace_if(v.begin(), v.end(), bind2nd(greater_equal<int>(), 20), 2000);
    for_each(v.begin(), v.end(), myPrint);
    cout << endl;

    cout << "自定义防函数替换:" << endl;
    replace_if(v.begin(), v.end(), MyCompare(20), 60);
    for_each(v.begin(), v.end(), myPrint);
}


int main(int argc, char const *argv[])
{
    test01();
    return 0;
}

4. swap

功能:

交换两个容器的元素, 需要是同一类型的容器

函数原型:

swap(v1, v2);
参数说明:
v1 容器1
v2 容器2
#include <iostream>
#include <fstream>
#include <string>
#include <vector>
#include <functional>
#include <algorithm>
using namespace std;

// swap


void myPrint(int val){
    cout << val << " ";
}

class MyCompare{
public:
    MyCompare(int num) : num(num){}
    bool operator()(int val){
        return val >= 20;
    }
    int num;
};

void test01()
{
    vector<int> v1;
    vector<int>v2;
    for (int i = 0; i < 10; i++)
    {
        v1.push_back(i);
        v2.push_back(i+100);
    }
    cout << "交换前" << endl;
    for_each(v1.begin(), v1.end(), myPrint);
    cout << endl;
    for_each(v2.begin(), v2.end(), myPrint);
    cout << endl;

    cout << "交换后" << endl;
    swap(v1, v2);
    for_each(v1.begin(), v1.end(), myPrint);
    cout << endl;
    for_each(v2.begin(), v2.end(), myPrint);
    cout << endl;

}


int main(int argc, char const *argv[])
{
    test01();
    return 0;
}


http://www.kler.cn/a/534215.html

相关文章:

  • Java进阶学习之路
  • Spring AI 智能体通过 MCP 集成本地文件数据
  • Android原生开发入门
  • 为AI聊天工具添加一个知识系统 之87 详细设计之28 Derivation 统一建模元模型 之1
  • 数科OFD证照生成原理剖析与平替方案实现
  • Mac M1 Comfyui 使用MMAudio遇到的问题解决?
  • FastAPI与Selenium:打造高效的Web数据抓取服务
  • 【Rancher】简化Kubernetes容器管理与部署的开源平台
  • AlwaysOn 可用性组副本所在服务器以及该副本上数据库的各项状态信息
  • kamailio-osp模块
  • 洛谷P2789 直线交点数
  • 除了 Python,还有哪些语言可以调用淘宝 API?
  • 深度学习系列--02.损失函数
  • k8m 是一款轻量级、跨平台的 Kubernetes 仪表板
  • RabbitMQ:python基础调用
  • DS图(中)(19)
  • 【分布式架构理论2】分布式架构要处理的问题及解决方案
  • 【自然语言处理(NLP)】Bahdanau 注意力(Bahdanau Attention)原理及代码实现
  • Day36-【13003】短文,数组的行主序方式,矩阵的压缩存储,对称、三角、稀疏矩阵和三元组线性表,广义表求长度、深度、表头、表尾等
  • 02、NodeJS学习笔记,第二节:express与中间件
  • Redis常见数据类型与编码方式
  • RabbitMQ 与 Kafka 的核心区别,如何选择合适的消息中间件?
  • 【LLM】为何DeepSeek 弃用MST却采用Rejection采样
  • 洛谷P2638 安全系统
  • 解锁.NET Fiddle:在线编程的神奇之旅
  • 【Elasticsearch】filter聚合