C++ 拷贝替换算法

news2025/1/8 11:46:57

🤔拷贝替换算法:

🙂1.copy  拷贝

在 C++ STL 中,copy()是一种常用的算法,用于将一个指定范围内的元素复制到目标位置中,不会改变原有序列的大小。

copy()的函数原型为:

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

📖其中,first 和 last 分别表示被复制序列的起始位置和结束位置d_first 表示目标序列的起始位置。

📖copy() 函数从源序列([first, last))中复制元素到目标序列([d_first, d_first+(last-first)))中。它返回目标序列中最后一个被写入元素的后继位置。

copy() 函数可以对标准数组、STL 容器等基本类型以及自定义类型进行操作。

🔍代码示例:

#include<iostream>
#include<algorithm>
#include<vector>
using namespace std;
void print(int val)
{
	cout << val<<" ";
}
int main()
{
	vector<int>d1;
	for (int i = 0; i < 10; i++)
	{
		d1.push_back(i);
	}
	vector<int>d2;
	d2.resize(10);
	copy(d1.begin(), d1.end(), d2.begin());
	cout << "拷贝后:";
	for_each(d2.begin(), d2.end(), print);
}

🔍运行结果:

🙂 2.replace   替换

在 C++ STL 中,replace()是一种常用的算法,用于在范围内以新值替换旧值。

replace()的函数原型为:

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

📖replace() 函数将输入范围 first 至 last-1 中等于 old_value 的元素替换为 new_value

🔍代码示例:

#include<iostream>
#include<algorithm>
#include<vector>
using namespace std;
void print(int val)
{
	cout << val << " ";
}
int main()
{
	vector<int>d1;
	
		d1.push_back(10);
		d1.push_back(20);
		d1.push_back(30);
		d1.push_back(40);
		d1.push_back(20);  
		d1.push_back(20);
		d1.push_back(30);
		d1.push_back(20);
	//替换所有的20为2000
	replace(d1.begin(),d1.end(),20 ,2000);

	cout << "替换后";
	for_each(d1.begin(), d1.end(), print);
}

🔍 运行结果:

🙂 3.replace_if    按条件替换

在 C++ STL 中,replace_if 是一种常用的算法,用于在指定的范围内以新值替换符合特定判定条件的值

replace_if  的函数原型为:

template<class ForwardIt, class UnaryPredicate, class T>
void replace_if(ForwardIt first, ForwardIt last, UnaryPredicate p, const T &new_value);

📖first  last 分别表示需要替换的序列的起始位置和结束位置p 是一个一元谓词(即接受一个参数并返回 bool 值的函数),用于判断每个元素是否需要被替换;new_value 表示新值。

📖replace_if() 函数将输入范围 first 至 last-1 中满足 p 判定条件的元素替换为 new_value

🔍代码示例:

我们把比30大的元素都替换为2000.

#include<iostream>
#include<algorithm>
#include<vector>
using namespace std;
class greater30
{
public:
	bool operator() (int val)
	{
		if (val < 30)
		{
			return false;
		}
		return true;
	}
};
void print(int val)
{
	cout << val << " ";
}
int main()
{
	vector<int>d1;
	
		d1.push_back(10);
		d1.push_back(20);
		d1.push_back(30);
		d1.push_back(40);
		d1.push_back(20);  
		d1.push_back(20);
		d1.push_back(30);
		d1.push_back(20);
	//替换所有的不符合条件的
	replace_if(d1.begin(),d1.end(),greater30(), 2000);

	cout << "替换后";
	for_each(d1.begin(), d1.end(), print);
}

🔍运行结果:

🙂 4.swap  交换

在 C++ STL 中,swap是一种常用的算法,用于交换两个对象的值,可以用于任何支持拷贝构造函数和赋值操作符的类型

swap的函数原型为:

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

其中,a 和 b 分别表示需要交换的两个对象。

📖swap() 函数交换两个对象的值,不需要为对象分配新的内存空间。需要注意的是,对于大型对象,使用 swap() 函数比直接赋值更高效。

📖swap() 函数可以对任何支持拷贝构造函数和赋值操作符的类型进行操作,包括基本类型和自定义类型。

🔍代码示例:

#include<iostream>
#include<algorithm>
#include<vector>
using namespace std;

void print(int val)
{
	cout << val << " ";
}
int main()
{
	vector<int>d1;
	vector<int>d2;
		d1.push_back(10);
		d1.push_back(20);
		d1.push_back(30);
		d1.push_back(40);
		d1.push_back(20);  
		d1.push_back(20);
		d1.push_back(30);
		d1.push_back(20);

		d2.push_back(100);

		cout << "交换前";
		cout << "d1:";
		for_each(d1.begin(), d1.end(), print);
		cout << endl;
		cout << "d2:";
		for_each(d2.begin(), d2.end(), print);
		cout << endl;
		cout << "交换后";
		swap(d1,d2);
		cout << "d1:";
		for_each(d1.begin(), d1.end(), print);
		cout << endl;
		cout << "d2:";
		for_each(d2.begin(), d2.end(), print);
	
}

🔍运行结果:

 

🤔结束!

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/591108.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

深度剖析 Vue.js 经典知识点之:SPA、SSR与MVVM

SPA 更多精彩内容&#xff0c;请微信搜索“前端爱好者“&#xff0c; 戳我 查看 。‘ 谈一谈你对 SPA 单⻚面的理解&#xff0c;它的优缺点分别是什么 SPA&#xff08; single-page application &#xff09;仅在 Web ⻚面初始化时加载相应的 HTML、JavaScript 和 CSS。 一旦…

如何创建springboot项目

SpringBoot 优点 可快速构建spring应用直接嵌入tomcat、jetty、undenrtow服务器&#xff08;无须部署war文件&#xff09;提供依赖启动器&#xff08;starter&#xff09;简化构建配置极大程度的自动化配置Spring和第三方库提供生产就绪功能&#xff0c;例如指标监控检测、外部…

讯飞星火认知大模型与ChatGPT的对比分析

引言&#xff1a; 人工智能是当今科技领域的热门话题&#xff0c;自然语言处理是人工智能的重要分支。自然语言处理的目标是让计算机能够理解和生成自然语言&#xff0c;实现人机交互和智能服务。近年来&#xff0c;随着深度学习的发展&#xff0c;自然语言处理领域出现了许多创…

桶排序 — 计数排序和基数排序

计数排序 int类型数组&#xff0c;其中存的是员工的年龄。比如说16 - 150。对于这样的数据来讲&#xff0c;数据状况是受限的。此时如果将数组从小到大进行排序&#xff0c;该如果实现&#xff1f; 这个实现很简单&#xff0c;实现一个统计数组范围从 0 ~ 150&#xff0c;遍历原…

UNIX网络编程卷一 学习笔记 第十七章 ioctl操作

ioctl函数传统上一直作为那些不适合归入现有已定义类别的特性的系统接口。POSIX正在通过创建特定的包装函数来代替ioctl函数的某些功能&#xff0c;以取而代之的是那些已被POSIX标准化的函数。例如&#xff0c;Unix终端接口传统上使用ioctl函数访问&#xff0c;而POSIX为终端创…

在idea中创建一个SpringBoot模块

方式一&#xff1a;自动创建&#xff08;需要联网&#xff09; 第一步&#xff1a;新建模块 按住ctrlshiftalts&#xff0c;打开项目结构&#xff0c;选择新建模块&#xff1b; 第二步&#xff1a;选择Spring Web &#xff08;1&#xff09;选择SpringBoot版本&#xff0c…

WebrtcNode, publish-sdp offer 流程(1)

1. AmqpClient - New message received sdp offer 的消息 AmqpClient - RpcServer New message received {method: onTransportSignaling,args: [aa230ce0863e42baa8bae5c14e91e809,{sdp: v0\r\n o- 2367615733001925388 2 IN IP4 127.0.0.1\r\n s-\r\n t0 0\r\n agroup:BUND…

quickstart Guide快速入门

本文档参考backtrader官方文档&#xff0c;是官方文档的完整中文翻译&#xff0c;可作为backtrader中文教程、backtrader中文参考手册、backtrader中文开发手册、backtrader入门资料使用。 快速入门章节目录 快速入门使用平台从0到100&#xff1a;一步一步的演示基本设置设置现…

C++ set类成员函数介绍 (set和multiset)

目录 &#x1f914;set模板介绍&#xff1a; &#x1f914;特点&#xff1a; &#x1f914;set的成员函数&#xff1a; &#x1f60a;set构造函数&#xff1a; &#x1f50d;代码实例&#xff1a; &#x1f50d;运行结果&#xff1a; &#x1f60a; set赋值函数&#xf…

IMX6ULL裸机篇之I2C相关寄存器

一. I2C实验 I2C时钟选择与传输速率 1. IMX6ULL的 I2C频率标准模式 100kbit/S&#xff0c;快速模式为 400Kbit/S 2. 时钟源选择 perclk_clk_rootipg_clk_root66MHz&#xff08;由之前的时钟实验章节可以知道是 66MHz&#xff09;。 二. I2C 寄存器配置 I2Cx_IFDR寄存器&…

《计算机组成原理》唐朔飞 第5章 输入输出系统 - 学习笔记

写在前面的话&#xff1a;此系列文章为笔者学习计算机组成原理时的个人笔记&#xff0c;分享出来与大家学习交流。使用教材为唐朔飞第3版&#xff0c;笔记目录大体与教材相同。 网课 计算机组成原理&#xff08;哈工大刘宏伟&#xff09;135讲&#xff08;全&#xff09;高清_…

chatgpt赋能python:Python中用什么表示空值?

Python中用什么表示空值&#xff1f; 在Python编程中&#xff0c;我们经常会遇到处理空值的场景。空值通常表示缺失的或未定义的值&#xff0c;这在数据处理和分析中尤其常见。那么&#xff0c;在Python中&#xff0c;究竟用什么来表示空值呢&#xff1f; None 在Python中&a…

6G显存玩转130亿参数大模型,仅需13行命令,RTX2060用户发来贺电

羊驼家族的Alpaca和Vicuna也都能运行&#xff0c;显存最低只需要6G&#xff0c;简直是低VRAM用户的福音有木有。 GitHub上的搭建教程火了之后&#xff0c;网友们纷纷跑来问苹果M2是不是也能跑。 这通操作的大致原理是利用最新版CUDA&#xff0c;可以将Transformer中任意数量的…

什么是先进存力?曙光存储:内铸数字底座,外成实践底气

5月26日&#xff0c;由DOIT联合中国电子学会共同举办的2023数据基础设施技术峰会在苏州举办。中科曙光存储产品事业部副总经理张新凤受邀参会&#xff0c;并在主论坛发表主题演讲&#xff0c;与数百位业内专业嘉宾伙伴共探存力发展未来。 什么样的存力能打造数字经济底座&#…

【笔记】【Javascript】javascript实现继承

前言 之前写过关于面向对象编程的文章&#xff0c;通过阅读别人的博客了解了一下Javascript实现继承的方法&#xff0c;并且使用图画的形式帮助了解&#xff0c;图是自己做的&#xff0c;若有偏差请读者帮忙指出&#xff0c;谢谢。笔记中有些个人理解后整理的笔记&#xff0c;…

基于STM32的ADC采样及各式滤波实现(HAL库,含VOFA+教程)

前言&#xff1a;本文为手把手教学ADC采样及各式滤波算法的教程&#xff0c;本教程的MCU采用STM32F103ZET6。以HAL库的ADC采样函数为基础进行教学&#xff0c;通过各式常见滤波的实验结果进行分析对比&#xff0c;搭配VOFA工具直观的展示滤波效果。ADC与滤波算法都是嵌入式较为…

MySQL进阶- Linux安装 和 索引

目录 Linux安装索引索引的概述索引的结构索引结构的介绍BtreeBtreeHash 索引的分类索引的语法&#xff08;创建&#xff0c;查看&#xff0c;删除等&#xff09;SQL性能分析SQL的执行频率&#xff08;查看SQL的执行频率&#xff09;慢查询日志show profilesexplain执行计划 索引…

video标签学习 xgplayer视频播放器分段播放mp4

文章目录 学习链接目标video标签自带视频和制作的视频区别video标签的src属性本地视频文件前端代码播放效果 服务器视频文件示例1后端代码前端代码播放效果 示例2后端代码前端代码播放效果 示例3后端配置前端代码播放效果 video对象video对象创建和获取video的属性video的方法v…

chatgpt赋能python:Python模块安装方法全解析

Python模块安装方法全解析 Python是一种功能强大的编程语言&#xff0c;拥有大量的开源库&#xff0c;这些库是在各种应用程序中使用的重要组件&#xff0c;它们能加速开发过程。不管你是初学者、中级者还是高级者&#xff0c;总会遇到需要安装第三方库的情况。但是安装库是一…

《Java并发编程实战》课程笔记(四)

互斥锁 原子性问题到底该如何解决呢&#xff1f; “同一时刻只有一个线程执行”这个条件非常重要&#xff0c;我们称之为互斥。如果我们能够保证对共享变量的修改是互斥的&#xff0c;那么&#xff0c;无论是单核 CPU 还是多核 CPU&#xff0c;就都能保证原子性了。 锁模型 …