c++常用stl算法

news2024/11/28 20:53:35

1、头文件

        这些算法通常包含在头文件<algorithm> <functional> <numeric>中。

 2、常用遍历算法

for_each(v.begin(),v.end(), 元素处理函数/仿函数) 

注意:在使用transform转存时,目标容器需要提取开辟合适的空间。 

void printfunc(int val) {
	cout << val << " ";
}
class Printoperator {
public:
	void operator()(int val) {
		cout << val << " ";
	}
};
int main() {

	vector<int> vi(10, 3);
	//输入一般函数完成for_each算法中的元素处理
	for_each(vi.begin(), vi.end(), printfunc);
	cout << endl;
	//输入仿函数完成for_each算法中的元素处理
	for_each(vi.begin(), vi.end(), Printoperator());
	cout << endl;
	system("pause");
	return 0;
}
class Printoperator {
public:
	int operator()(int val) {
		return val + 1;
	}
};
void print(vector<int> &v) {
	for (auto i : v) {
		cout << i << " ";
	}
	cout << endl;
}
int main() {

	vector<int> vi(10, 3);

	vector<int> vi2(4, 5);
	//需要提前给目标容器开辟空间,不然会报错
	vi2.resize(vi.size());
	transform(vi.begin(), vi.end(), vi2.begin(), Printoperator());
	print(vi2);
	system("pause");
	return 0;
}

3、常用查找算法

 find按值查找元素

函数原型:

         使用find查找自定义类型元素的时候,需要在对应类中重载==,以便find算法能知道该怎么比较。

class Person {
public:
	Person(int age, string name) {
		this->mAge = age;
		this->mName = name;
	}
	//帮助find查找元素
	bool operator==(const Person &p) {
		if (p.mAge == this->mAge && p.mName == this->mName) {
			return true;
		}
		else {
			return false;
		}
	}
	int mAge;
	string mName;
};
int main() {

	vector<Person> v;

	Person p1(10, "aaa");
	Person p2(20, "sss");
	Person p3(40, "ads");
	Person p4(10, "ccc");

	v.push_back(p1);
	v.push_back(p2);
	v.push_back(p3);
	v.push_back(p4);

	vector<Person>::iterator iter = find(v.begin(), v.end(), p2);

	if (iter != v.end()) {
		cout << "逮到 !!!" << endl;
	}
	system("pause");
	return 0;
}

 find_if按值查找元素

         利用find_if按自定义谓词找到合适的自定义类型元素:

class Person {
public:
	Person(int age, string name) {
		this->mAge = age;
		this->mName = name;
	}
	int mAge;
	string mName;
};
class FindPerson {
public:
	bool operator()(const Person &p) {
		return p.mAge > 20;
	}
};
int main() {

	vector<Person> v;

	Person p1(10, "aaa");
	Person p2(20, "sss");
	Person p3(40, "ads");
	Person p4(10, "ccc");

	v.push_back(p1);
	v.push_back(p2);
	v.push_back(p3);
	v.push_back(p4);

	vector<Person>::iterator iter = find_if(v.begin(), v.end(), FindPerson());


	if (iter != v.end()) {
		cout << (*iter).mName<<" 的年龄超过了20" << endl;
	}
	system("pause");
	return 0;
}

adjacent_find查找相邻重复元素 

         adjacen_find按自定义谓词查找相邻满足条件自定义元素:

class Person {
public:
	Person(int age, string name) {
		this->mAge = age;
		this->mName = name;
	}
	
	int mAge;
	string mName;
};
class FindPerson {
public:
	bool operator()(const Person &p1, const Person& p2) {
		if (p1.mAge == p2.mAge)
			return true;
		else
			return false;
	}
};
int main() {

	vector<Person> v;

	Person p1(10, "aaa");
	Person p2(20, "sss");
	Person p3(20, "sad");
	Person p4(40, "ads");
	Person p5(10, "ccc");

	v.push_back(p1);
	v.push_back(p2);
	v.push_back(p3);
	v.push_back(p4);
	v.push_back(p5);

	vector<Person>::iterator iter = adjacent_find(v.begin(), v.end(), FindPerson());

	if (iter != v.end()) {
		cout <<"有相邻年龄相同的人" << (*iter).mName <<"和" << (*(iter+1)).mName << endl;
	}
	else {
		cout << "没有相邻年龄相同的人" << endl;
	}
	system("pause");
	return 0;
}

binary_search查指定元素是否存在(不适用无序序列,必须有序且为升序序列) 

count统计元素出现次数

返回int

class Person {
public:
	Person(int age, string name) {
		this->mAge = age;
		this->mName = name;
	}
	//帮助count查找元素
	bool operator==(const Person &p) {
		if (p.mAge == this->mAge) {
			return true;
		}
		else {
			return false;
		}
	}
	int mAge;
	string mName;
};

int main() {

	vector<Person> v;

	Person p1(10, "aaa");
	Person p2(20, "sss");
	Person p3(20, "sad");
	Person p4(40, "ads");
	Person p5(10, "ccc");

	v.push_back(p1);
	v.push_back(p2);
	v.push_back(p3);
	v.push_back(p4);
	v.push_back(p5);

	int num = count(v.begin(), v.end(), p2);
	cout << "20岁的人有 " << num << "个"  << endl;
	
	system("pause");
	return 0;
}

count_if 按条件统计元素个数 ,返回int

count_if的谓词使用参见find_if。 

4、常用排序算法

        

 sort排序

 对自定义类型排序:

class Person {
public:
	Person(int age, string name) {
		this->mAge = age;
		this->mName = name;
	}
	int mAge;
	string mName;
};
class SortPerson {
public:
	bool operator()(const Person& p1, const Person& p2) {
		if (p1.mAge > p2.mAge)
			return true;
		else
			return false;
	}
};
int main() {

	vector<Person> v;

	Person p1(10, "aaa");
	Person p2(20, "sss");
	Person p3(20, "sad");
	Person p4(40, "ads");
	Person p5(10, "ccc");

	v.push_back(p1);
	v.push_back(p2);
	v.push_back(p3);
	v.push_back(p4);
	v.push_back(p5);

	sort(v.begin(), v.end(), SortPerson());
	
	system("pause");
	return 0;
}

random_shuffle随机调序 

int main() {

	vector<Person> v;

	Person p1(10, "aaa");
	Person p2(20, "sss");
	Person p3(20, "sad");
	Person p4(40, "ads");
	Person p5(10, "ccc");

	v.push_back(p1);
	v.push_back(p2);
	v.push_back(p3);
	v.push_back(p4);
	v.push_back(p5);

	random_shuffle(v.begin(), v.end());
	//cout << "20岁的人有 " << num << "个"  << endl;
	
	system("pause");
	return 0;
}

 

 merge合并容器元素(容器必须有序,提取个目标容器分配空间)

	vector<int> vi1{ 1,2,3,4,5 };
	vector<int> vi2{ 2,3,4,5,7 };

	vector<int> target;
	//提前个target开辟空间
	target.resize((vi1.size() + vi2.size()));

	merge(vi1.begin(), vi1.end(), vi2.begin(), vi2.end(),target.begin());

reverse反转容器中的元素 (不需要谓词就能实现自定义类型反转)

 

	vector<Person> v;

	Person p1(10, "aaa");
	Person p2(20, "sss");
	Person p3(20, "sad");
	Person p4(40, "ads");
	Person p5(10, "ccc");

	v.push_back(p1);
	v.push_back(p2);
	v.push_back(p3);
	v.push_back(p4);
	v.push_back(p5);

	reverse(v.begin(), v.end());

5、常用拷贝替换生成算法

copy拷贝(需要预先开辟空间)

注:在拷贝自定义类时,需要有对应的空默认构造函数,如:Person(){}。 

	vector<Person> v;

	Person p1(10, "aaa");
	Person p2(20, "sss");
	Person p3(20, "sad");
	Person p4(40, "ads");
	Person p5(10, "ccc");

	v.push_back(p1);
	v.push_back(p2);
	v.push_back(p3);
	v.push_back(p4);
	v.push_back(p5);

	vector<Person> target;
	target.resize(v.size());

	copy(v.begin(), v.end(), target.begin());

replace元素替换

	vector<int> vi1{ 1,2,3,4,5 };

	replace(vi1.begin(), vi1.end(), 1, 20);

replace_if满足条件元素替换

class Person {
public:
	Person() {
	}
	Person(int age, string name) {
		this->mAge = age;
		this->mName = name;
	}
    int mAge;
	string mName;
};

class ReplacePerson {
public:
	bool operator()(const Person& p) {
		if (p.mAge > 20)
			return true;
		else
			return false;
	}
};
int main() {

	vector<Person> v;

	Person p1(10, "aaa");
	Person p2(20, "sss");
	Person p3(20, "sad");
	Person p4(40, "ads");
	Person p5(10, "ccc");

	
	v.push_back(p1);
	v.push_back(p2);
	v.push_back(p3);
	v.push_back(p4);
	v.push_back(p5);

	Person p6(10, "dsaf");

	replace_if(v.begin(), v.end(), ReplacePerson(), p6);

	system("pause");
	return 0;
}

swap交换容器元素

 6、常用算术生成算法

accumulate计算累加

 

自定义类型的某成员变量累加:(也可以采用仿函数形式)

class Person {
public:
	Person() {
	}
	Person(int age, string name) {
		this->mAge = age;
		this->mName = name;
	}
	int mAge;
	string mName;
};

int Age_acc(int pre,Person& p) {
	return pre + p.mAge;
}
int main() {

	vector<Person> v;

	Person p1(10, "aaa");
	Person p2(20, "sss");
	Person p3(20, "sad");
	Person p4(40, "ads");
	Person p5(10, "ccc");

	
	v.push_back(p1);
	v.push_back(p2);
	v.push_back(p3);
	v.push_back(p4);
	v.push_back(p5);

	Person p6(10, "dsaf");
	int acu = accumulate(v.begin(), v.end(), 0, Age_acc);

	system("pause");
	return 0;
}

 fill向容器中填充元素

 7、常用集合算法

 set_intersection求两个容器交集(必须预先开辟目标容器空间)

set_union求两个容器并集

set_difference求两个容器差集

 

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

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

相关文章

【C++】类和对象入门必知

面向过程和面向对象的初步认识类的引入类的定义类的访问限定符封装类的作用域类的实例化类对象模型this指针C语言和C实现Stack的对比面向过程和面向对象的初步认识 C语言是面向过程的&#xff0c;关注的是过程&#xff0c;分析出求解问题的步骤&#xff0c;通过函数调用逐步解…

【归一化小记】,batchnorm,layernorm,IN,GN,分布式归一化...

BatchNorm 最早在全连接网络中被提出&#xff0c;对每个神经元的输入做归一化。扩展到 CNN 中&#xff0c;就是对每个卷积核的输入做归一化&#xff0c;或者说在 channel 之外的所有维度做归一化。 BN 带来的好处有很多&#xff0c;这里简单列举几个&#xff1a; 防止过拟合&am…

【HTML】HTML 表单 ④ ( textarea 文本域控件 | select 下拉列表控件 )

文章目录一、textarea 文本域控件二、select 下拉列表控件一、textarea 文本域控件 textarea 文本域 控件 是 多行文本输入框 , 标签语法格式如下 : <textarea cols"每行文字字符数" rows"文本行数">多行文本内容 </textarea>实际开发中 并不…

聚观早报 | 嘀嗒出行重启赴港IPO;饿了么到店业务将与高德合并

点击蓝字 / 关注我们今日要闻&#xff1a;嘀嗒出行重启赴港 IPO&#xff1b;饿了么到店业务将与高德合并&#xff1b;美团香港骑手月收入高达3.5万港元&#xff1b;腾讯或引进Meta旗下VR眼镜Quest 2&#xff1b;苹果将阻止用户免费装开测版iOS 17 嘀嗒出行重启赴港 IPO 港交所文…

Java企业开发学习笔记(2)利用组件注解符精简Spring配置文件

该文章主要为完成实训任务&#xff0c;详细实现过程及结果见【http://t.csdn.cn/iSeSH】 文章目录一、 利用组件注解符精简Spring配置文件1.1 创建新包1.2 复制四个类1.3 修改杀龙任务类1.4 修改救美任务类1.5 修改勇敢骑士类1.6 修改救美骑士类1.7 创建Spring配置文件1.8 创建…

【数据库】redis数据持久化

目录 数据持久化 一&#xff0c; RDB 1&#xff0c; 什么是RDB 2&#xff0c;持久化流程 3&#xff0c; 相关配置 案例演示&#xff1a; 4&#xff0c; 备份和恢复 1、备份 2、恢复 3&#xff0c;优势 4&#xff0c; 劣势 二&#xff0c;AOF 1&#xff0c;什么是A…

Java笔记026-集合/数组、Collection接口、ArrayList、Vector、LinkedList

集合集合的理解和好处保存多个数据使用的是数组&#xff0c;分析数组的弊端数组1、长度开始必须指定&#xff0c;而且一旦指定&#xff0c;不能更改2、保存的必须为同一类型的元素3、使用数组进行增加/删除元素的示意代码-比较麻烦Person数组扩容示意代码Person[] pers new Pe…

ChatGPT三个关键技术

情景学习&#xff08;In-context learning&#xff09; 对于一些LLM没有见过的新任务&#xff0c;只需要设计一些任务的语言描述&#xff0c;并给出几个任务实例&#xff0c;作为模型的输入&#xff0c;即可让模型从给定的情景中学习新任务并给出满意的回答结果。这种训练方式能…

论文笔记:How transferable are features in deep neural networks? 2014年NIP文章

文章目录一、背景介绍二、方法介绍三、实验论证四、结论五、感想参考文献一、背景介绍 1.问题介绍&#xff1a; 许多在自然图像上训练的深度神经网络都表现出一个奇怪的共同现象&#xff1a;在第一层&#xff0c;它们学习类似于Gabor过滤器和color blobs的特征。这样的第一层特…

c++提高篇——list容器

一、基本概念 功能:将数据进行链式存储 链表&#xff08;(list)是一种物理存储单元上非连续的存储结构&#xff0c;数据元素的逻辑顺序是通过链表中的指针链接实现的&#xff0c;链表由一系列结点组成。 结点的组成:一个是存储数据元素的数据域&#xff0c;另一个是存储下一个…

3DVR营销是什么?是否成为市场热门?

在当今市场经济环境中&#xff0c;营销对于在企业发展中的作用至关重要。市场是企业发展的战场&#xff0c;谁能在市场营销方面做得更好&#xff0c;就能够吸引公域平台流量、占据主流市场、开拓新局面从而稳定现有规模。这将确保企业不被市场淘汰&#xff0c;而是能够可持续性…

CSS(配合html的网页编程)

续上一篇博客,CSS是前端三大将中其中的一位,主要负责前端的皮,也就是负责html的装饰.一、基本语法规则也就是:选择器若干属性声明(选中一个元素然然后进行属性声明)CSS代码是放在style标签中,它可以放在head中也可以放在body中 ,可以放到代码的任意位置.color也就是设置想要输入…

如何描述元素与元素间的逻辑关系?

逻辑结构反映的是数据元素之间的关系&#xff0c;它们与数据元素在计算机中的存储位置无关&#xff0c;是数据结构在用户面前所呈现的形式。根据不同的逻辑结构来分&#xff0c;数据结构可分为集合、线性结构、树形结构和图形结构4种形式&#xff0c;接下来分别进行简要介绍。 …

宝塔搭建实战php源码云切程序转码m3u8生程序开源源码

大家好啊&#xff0c;我是测评君&#xff0c;欢迎来到web测评。 今天给大家分享一套php云切片转码的源码&#xff0c;分享自己的视频但是由于视频文件太大&#xff0c;服务器带宽太小&#xff0c;导致分享困难&#xff0c;部署这套系统后&#xff0c;就可以在上传视频后切成ts格…

车机开发—【CarService启动流程】

汽车架构&#xff1a;车载HAL是汽车与车辆网络服务之间的接口定义&#xff08;同时保护传入的数据&#xff09;&#xff1a; 车载HAL与Android Automotive架构&#xff1a; Car App&#xff1a;包括OEM和第三方开发的AppCar API&#xff1a;内有包含CarSensorManager在内的AP…

5个有效的华为(HUAWEI)手机数据恢复方法

5个有效的手机数据恢复方法 华为智能手机中的数据丢失比许多人认为的更为普遍。发生这种类型的丢失有多种不同的原因&#xff0c;因此数据恢复软件的重要性。您永远不知道您的智能手机何时会在这方面垮台&#xff1b;因此&#xff0c;预防总比哀叹好&#xff0c;这就是为什么众…

通过 FTP 使用 Python 自动压缩网站图像

图像压缩对于技术SEO世界来说并不陌生,但是随着核心生命体征形式的网站性能是一个排名因素,现在是时候开始采取行动了。我已经做了几十次网站审计,我发现 80% 的网站性能问题都可以在图像或 JavaScript 下进行。当我看到图像是一个大问题时,我会欢呼,因为它是最容易解决的…

注意啦,面试通过后,别忘了教师资格证认定

所有要「教师资格证认定」教程的宝子们看过来面试合格的小伙伴都可以进行认定工作 . 认定时间 查询各省份认定公告&#xff0c;确定认定时间范围。以下是公告汇总网址&#xff08;https://www.jszg.edu.cn/portal/qualification_cert/dynamics?id21691&#xff09; 认定次数 每…

【jQuery】js实现文件浏览功能

1.说明 近期遇到一个浏览用户文件的需求&#xff0c;类似于访问百度网盘那样的列表&#xff0c;包含文件和文件夹&#xff0c;这个功能实现起来很简单&#xff0c;从服务器获取到的文件列表至少要有文件id、父级文件id、是否文件夹这三个字段 2.html设计 前端排版看你实际情…

x86架构设备的OpenWrt的空间扩容问题

openwrt固件是squashfs-combined-efi非exf4格式 直接将原有根分区扩容 用插件是&#xff1a;fdisk,losetup,resize2fs,blkid df -h fdisk -l fdisk /dev/sda //进入fdisk分区管理工具注意fdisk后参数是磁盘名称&#xff0c;是要根据实际情况填写 fdisk /dev/sda //进入fdi…