Linux C++ 041-STL之集合算法

2024-04-19 02:04
文章标签 算法 c++ linux 集合 stl 041

本文主要是介绍Linux C++ 041-STL之集合算法,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

Linux C++ 041-STL之集合算法

本节关键字:Linux、C++、集合算法
相关库函数:set_intersection、set_union、set_difference

set_intersection()

功能描述:求两个容器的交集
函数原型:

set_intersection(iterator beg1, iterator end1, iterator beg2, iterator end2, iterator dest);
// dest - 目标容器的起始迭代器

示例:

#include <numeric>
#include <algorithm>class MyPrint
{
public:void operator()(const int val){cout << val << " ";}
};void test01()
{vector<int> v1;vector<int> v2;for(int i=0;i<5;i++){v1.push_back(i);v2.push_back(i+2);}vectot<int> vTarget;//开辟空间,特殊情况,取小容器的sizevTarget.resize(min(v1.size(), v2.size()));vector<int>::iterator itEnd = set_intersection(v1.begin(), v1.end(), v2.begin(), v2.end(), vTarget.begin());for_each(vTarget.begin(), itEnd, MyPrint());cout << endl;
}

总结:
1.求交集的两个集合必须是有序序列
2.目标容器记得提前开辟空间,取小容器的大小
3.set_intersection返回值为交集中最后一个元素的位置

set_union()

功能描述:求两个容器的并集
函数原型:

set_union(iterator beg1, iterator end1, iterator beg2, iterator end2, iterator dest);
// dest - 目标容器的起始迭代器

示例:

#include <numeric>
#include <algorithm>class MyPrint
{
public:void operator()(const int val){cout << val << " ";}
};void test01()
{vector<int> v1;vector<int> v2;for(int i=0;i<5;i++){v1.push_back(i);v2.push_back(i+4);}vectot<int> vTarget;//开辟空间,特殊情况,取小容器的sizevTarget.resize(v1.size() + v2.size());vector<int>::iterator itEnd = set_union(v1.begin(), v1.end(), v2.begin(), v2.end(), vTarget.begin());for_each(vTarget.begin(), itEnd, MyPrint());cout << endl;
}

总结:
1.求并集的两个集合必须是有序序列
2.目标容器记得提前开辟空间,取两个容器大小的和
3.set_union返回值为并集中最后一个元素的位置

set_difference()

功能描述:求两个容器的差集
函数原型:

set_difference(iterator beg1, iterator end1, iterator beg2, iterator end2, iterator dest);
// dest - 目标容器的起始迭代器

示例:

#include <numeric>
#include <algorithm>class MyPrint
{
public:void operator()(const int val){cout << val << " ";}
};void test01()
{vector<int> v1;vector<int> v2;for(int i=0;i<5;i++){v1.push_back(i);v2.push_back(i+2);}vectot<int> vTarget;//开辟空间,特殊情况,取小容器的sizevTarget.resize( max(v1.size(), v2.size()) );vector<int>::iterator itEnd = set_difference(v1.begin(), v1.end(), v2.begin(), v2.end(), vTarget.begin());for_each(vTarget.begin(), itEnd, MyPrint());cout << endl;itEnd = set_difference(v2.begin(), v2.end(), v1.begin(), v1.end(), vTarget.begin());for_each(vTarget.begin(), itEnd, MyPrint());cout << endl;
}

总结:
1.求差集的两个集合必须是有序序列
2.目标容器记得提前开辟空间,取大容器的大小
3.set_difference返回值为差集中最后一个元素的位置

这篇关于Linux C++ 041-STL之集合算法的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/916365

相关文章

C#如何调用C++库

《C#如何调用C++库》:本文主要介绍C#如何调用C++库方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录方法一:使用P/Invoke1. 导出C++函数2. 定义P/Invoke签名3. 调用C++函数方法二:使用C++/CLI作为桥接1. 创建C++/CL

Linux之systemV共享内存方式

《Linux之systemV共享内存方式》:本文主要介绍Linux之systemV共享内存方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、工作原理二、系统调用接口1、申请共享内存(一)key的获取(二)共享内存的申请2、将共享内存段连接到进程地址空间3、将

快速修复一个Panic的Linux内核的技巧

《快速修复一个Panic的Linux内核的技巧》Linux系统中运行了不当的mkinitcpio操作导致内核文件不能正常工作,重启的时候,内核启动中止于Panic状态,该怎么解决这个问题呢?下面我们就... 感谢China编程(www.chinasem.cn)网友 鸢一雨音 的投稿写这篇文章是有原因的。为了配置完

C++如何通过Qt反射机制实现数据类序列化

《C++如何通过Qt反射机制实现数据类序列化》在C++工程中经常需要使用数据类,并对数据类进行存储、打印、调试等操作,所以本文就来聊聊C++如何通过Qt反射机制实现数据类序列化吧... 目录设计预期设计思路代码实现使用方法在 C++ 工程中经常需要使用数据类,并对数据类进行存储、打印、调试等操作。由于数据类

Linux命令之firewalld的用法

《Linux命令之firewalld的用法》:本文主要介绍Linux命令之firewalld的用法,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录linux命令之firewalld1、程序包2、启动firewalld3、配置文件4、firewalld规则定义的九大

Linux之计划任务和调度命令at/cron详解

《Linux之计划任务和调度命令at/cron详解》:本文主要介绍Linux之计划任务和调度命令at/cron的使用,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录linux计划任务和调度命令at/cron一、计划任务二、命令{at}介绍三、命令语法及功能 :at

Linux下如何使用C++获取硬件信息

《Linux下如何使用C++获取硬件信息》这篇文章主要为大家详细介绍了如何使用C++实现获取CPU,主板,磁盘,BIOS信息等硬件信息,文中的示例代码讲解详细,感兴趣的小伙伴可以了解下... 目录方法获取CPU信息:读取"/proc/cpuinfo"文件获取磁盘信息:读取"/proc/diskstats"文

Linux内核参数配置与验证详细指南

《Linux内核参数配置与验证详细指南》在Linux系统运维和性能优化中,内核参数(sysctl)的配置至关重要,本文主要来聊聊如何配置与验证这些Linux内核参数,希望对大家有一定的帮助... 目录1. 引言2. 内核参数的作用3. 如何设置内核参数3.1 临时设置(重启失效)3.2 永久设置(重启仍生效

C++使用printf语句实现进制转换的示例代码

《C++使用printf语句实现进制转换的示例代码》在C语言中,printf函数可以直接实现部分进制转换功能,通过格式说明符(formatspecifier)快速输出不同进制的数值,下面给大家分享C+... 目录一、printf 原生支持的进制转换1. 十进制、八进制、十六进制转换2. 显示进制前缀3. 指

C++中初始化二维数组的几种常见方法

《C++中初始化二维数组的几种常见方法》本文详细介绍了在C++中初始化二维数组的不同方式,包括静态初始化、循环、全部为零、部分初始化、std::array和std::vector,以及std::vec... 目录1. 静态初始化2. 使用循环初始化3. 全部初始化为零4. 部分初始化5. 使用 std::a