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

<C++学习>C++ Boost 算法集合操作教程

C++ Boost 算法集合操作教程

Boost 提供了一些非常强大的算法库,用于对集合进行高效的操作。这些集合算法库主要提供了便捷的接口,支持常见的集合运算(如并集、交集、差集等)、排列组合和更高级的容器操作。


1. Boost 算法库简介

Boost 算法集合操作主要集中在以下几个模块:

  1. Boost.SetOperations:集合的并集、交集、差集、对称差等操作。
  2. Boost.Range:增强对区间和容器的操作。
  3. Boost.Permutation:排列和组合算法。
  4. Boost.Graph:提供图论相关算法的集合操作。

头文件

#include <boost/algorithm/cxx11/all_of.hpp> // 支持 C++11 类似的集合算法
#include <boost/algorithm/set_operations.hpp> // 集合操作

2. Boost.SetOperations

Boost.SetOperations 提供了一系列的集合操作函数,如并集、交集、差集和对称差。以下是常见用法。


2.1 并集

功能

将两个集合的所有元素合并为一个集合。

示例
#include <boost/algorithm/set_operations.hpp>
#include <vector>
#include <iostream>int main() {std::vector<int> set1 = {1, 2, 3, 4};std::vector<int> set2 = {3, 4, 5, 6};std::vector<int> result;boost::set_union(set1, set2, std::back_inserter(result));std::cout << "Union: ";for (int i : result) {std::cout << i << " ";}return 0;
}
输出
Union: 1 2 3 4 5 6

2.2 交集

功能

找出两个集合中共有的元素。

示例
#include <boost/algorithm/set_operations.hpp>
#include <vector>
#include <iostream>int main() {std::vector<int> set1 = {1, 2, 3, 4};std::vector<int> set2 = {3, 4, 5, 6};std::vector<int> result;boost::set_intersection(set1, set2, std::back_inserter(result));std::cout << "Intersection: ";for (int i : result) {std::cout << i << " ";}return 0;
}
输出
Intersection: 3 4

2.3 差集

功能

找出一个集合中独有的元素(即从第一个集合中删除所有在第二个集合中的元素)。

示例
#include <boost/algorithm/set_operations.hpp>
#include <vector>
#include <iostream>int main() {std::vector<int> set1 = {1, 2, 3, 4};std::vector<int> set2 = {3, 4, 5, 6};std::vector<int> result;boost::set_difference(set1, set2, std::back_inserter(result));std::cout << "Difference: ";for (int i : result) {std::cout << i << " ";}return 0;
}
输出
Difference: 1 2

2.4 对称差

功能

找出两个集合中不重叠的元素。

示例
#include <boost/algorithm/set_operations.hpp>
#include <vector>
#include <iostream>int main() {std::vector<int> set1 = {1, 2, 3, 4};std::vector<int> set2 = {3, 4, 5, 6};std::vector<int> result;boost::set_symmetric_difference(set1, set2, std::back_inserter(result));std::cout << "Symmetric Difference: ";for (int i : result) {std::cout << i << " ";}return 0;
}
输出
Symmetric Difference: 1 2 5 6

3. Boost.Range

Boost.Range 提供了一系列用于增强容器和范围操作的工具。


3.1 Filtered Range(过滤范围)

示例:筛选偶数
#include <boost/range/adaptors.hpp>
#include <boost/range/algorithm.hpp>
#include <vector>
#include <iostream>int main() {std::vector<int> nums = {1, 2, 3, 4, 5, 6};// 筛选偶数auto evenNums = nums | boost::adaptors::filtered([](int x) { return x % 2 == 0; });std::cout << "Even numbers: ";for (int i : evenNums) {std::cout << i << " ";}return 0;
}
输出
Even numbers: 2 4 6

3.2 Transformed Range(变换范围)

示例:平方操作
#include <boost/range/adaptors.hpp>
#include <boost/range/algorithm.hpp>
#include <vector>
#include <iostream>int main() {std::vector<int> nums = {1, 2, 3, 4};// 将每个元素平方auto squares = nums | boost::adaptors::transformed([](int x) { return x * x; });std::cout << "Squares: ";for (int i : squares) {std::cout << i << " ";}return 0;
}
输出
Squares: 1 4 9 16

4. Boost.Permutation

Boost 的排列组合工具可以生成元素的排列或组合。


4.1 排列生成

示例:全排列
#include <boost/range/algorithm.hpp>
#include <vector>
#include <iostream>int main() {std::vector<int> nums = {1, 2, 3};std::cout << "Permutations: " << std::endl;do {for (int i : nums) {std::cout << i << " ";}std::cout << std::endl;} while (boost::range::next_permutation(nums));return 0;
}
输出
Permutations: 
1 2 3
1 3 2
2 1 3
2 3 1
3 1 2
3 2 1

5. 综合示例:结合集合与过滤

以下示例展示了如何结合 Boost 集合操作与过滤功能,实现复杂的集合操作。

示例代码
#include <boost/algorithm/set_operations.hpp>
#include <boost/range/adaptors.hpp>
#include <vector>
#include <iostream>int main() {std::vector<int> set1 = {1, 2, 3, 4, 5, 6};std::vector<int> set2 = {4, 5, 6, 7, 8, 9};// 求并集std::vector<int> unionResult;boost::set_union(set1, set2, std::back_inserter(unionResult));// 筛选偶数auto evenUnion = unionResult | boost::adaptors::filtered([](int x) { return x % 2 == 0; });// 输出结果std::cout << "Even numbers in union: ";for (int i : evenUnion) {std::cout << i << " ";}return 0;
}
输出
Even numbers in union: 2 4 6 8

6. 学习建议

  1. 理解基础集合操作

    • 熟悉并集、交集、差集和对称差的概念和用法。
  2. 灵活使用 Range 适配器

    • 将集合操作与过滤或变换结合使用,可以大大简化代码。
  3. 参考文档与实践

    • Boost.SetOperations 官方文档
    • Boost.Range 官方文档

通过系统学习这些功能,你将能够高效处理各种复杂的集合操作场景!

相关文章:

<C++学习>C++ Boost 算法集合操作教程

C Boost 算法集合操作教程 Boost 提供了一些非常强大的算法库&#xff0c;用于对集合进行高效的操作。这些集合算法库主要提供了便捷的接口&#xff0c;支持常见的集合运算&#xff08;如并集、交集、差集等&#xff09;、排列组合和更高级的容器操作。 1. Boost 算法库简介 …...

Jaeger UI使用、采集应用API排除特定路径

Jaeger使用 注&#xff1a; Jaeger服务端版本为&#xff1a;jaegertracing/all-in-one-1.6.0 OpenTracing版本为&#xff1a;0.33.0&#xff0c;最后一个版本&#xff0c;停留在May 06, 2019。最好升级到OpenTelemetry。 Jaeger客户端版本为&#xff1a;jaeger-client-1.3.2。…...

设计一个利用事务特性可以阻塞线程的排他锁,并且通过注解和 AOP 来实现

设计思路&#xff1a; 利用数据库表记录锁标识&#xff1a;通过唯一标识符&#xff08;如方法名 参数&#xff09;&#xff0c;我们可以在数据库中插入一条记录&#xff0c;表示当前方法正在执行。这条记录需要记录插入时间。 注解&#xff1a;通过注解标识哪些方法需要加锁&a…...

【2024年华为OD机试】 (A卷,100分)- 对称美学(Java JS PythonC/C++)

一、问题描述 题目描述 对称就是最大的美学&#xff0c;现有一道关于对称字符串的美学。已知&#xff1a; 第1个字符串&#xff1a;R第2个字符串&#xff1a;BR第3个字符串&#xff1a;RBBR第4个字符串&#xff1a;BRRBRBBR第5个字符串&#xff1a;RBBRBRRBBRRBRBBR 相信你…...

【教程】数据可视化处理之2024年各省GDP排名预测!

过去的一年里&#xff0c;我国的综合实力显著提升&#xff0c;在新能源汽车、新一代战机、两栖攻击舰、航空航天、芯片电子、装备制造等领域位居全球前列。虽然全国各省市全年的经济数据公布还需要一段时间&#xff0c;但各地的工业发展数据&#xff0c;财政收入数据已大概揭晓…...

Java 将RTF文档转换为Word、PDF、HTML、图片

RTF文档因其跨平台兼容性而广泛使用&#xff0c;但有时在不同的应用场景可能需要特定的文档格式。例如&#xff0c;Word文档适合编辑和协作&#xff0c;PDF文档适合打印和分发&#xff0c;HTML文档适合在线展示&#xff0c;图片格式则适合社交媒体分享。因此我们可能会需要将RT…...

深度学习的原理和应用

一、深度学习的原理 深度学习是机器学习领域的一个重要分支&#xff0c;其原理基于多层神经网络结构和优化算法。以下是深度学习的核心原理&#xff1a; 多层神经网络结构&#xff1a;深度学习模型通常由多层神经元组成&#xff0c;这些神经元通过权重和偏置相互连接。输入数据…...

CAPL语法基础

CAPL语法基础 目录 CAPL语法基础1. 引言2. 数据类型、变量与常量2.1 数据类型2.2 变量2.3 常量2.4 案例1&#xff1a;使用变量和常量计算圆的面积 3. 运算符与表达式3.1 算术运算符3.2 关系运算符3.3 逻辑运算符3.4 位运算符3.5 案例2&#xff1a;使用运算符实现简单的逻辑判断…...

安卓studio生成apk步骤

在写完app之后虽然能在真机上运行 但是在文件夹中找不到相应的apk &#xff0c;注意&#xff01;&#xff01;&#xff01;安卓 studio中可以自动生动生成 apk 下面是生成步骤&#xff1a; 步骤1&#xff1a;build ->make project 步骤2&#xff1a;build ->Generate si…...

Azure主机windows2008就地升级十步

Azure上云主机的windows2008系统需要进行就地升级。 按着微软的升级路径&#xff1a;win2008-->win2012-->win2016-->win2022 第一步&#xff1a;创建快照备份&#xff0c;防止升级失败第二步&#xff1a;升级托管磁盘&#xff0c;在VM管理的地方将磁盘升级成托管磁盘…...

解锁 C# 与 LiteDB 嵌入式 NoSQL 数据库

一、开篇&#xff1a;邂逅 C# 与 LiteDB 新世界 在当今的软件开发领域&#xff0c;数据管理如同建筑的基石&#xff0c;而选择一款合适的数据库则是项目成功与否的关键因素之一。对于 C# 开发者来说&#xff0c;面对琳琅满目的数据库选项&#xff0c;如何抉择常常令人头疼。今…...

7 分布式定时任务调度框架

先简单介绍下分布式定时任务调度框架的使用场景和功能和架构&#xff0c;然后再介绍世面上常见的产品 我们在大型的复杂的系统下&#xff0c;会有大量的跑批&#xff0c;定时任务的功能&#xff0c;如果在独立的子项目中单独去处理这些任务&#xff0c;随着业务的复杂度的提高…...

七星棋类游戏源码:两百玩法开源修复

这套七星棋类源码&#xff0c;覆盖六大省区&#xff08;湖南双端、湖北、山西、江苏、贵州等&#xff09;&#xff0c;安卓与苹果端都能轻松适配&#xff0c;汇集 6 个端口与 200 多种子游戏玩法。此版本为二次开发修复版&#xff0c;功能完备且源码完全公开&#xff0c;包括乐…...

未来世界:科技引领的奇幻篇章

科技发展的这么快&#xff0c;未来的世界将会是什么样的呢&#xff1f; 在人类历史的长河中&#xff0c;科技始终是推动社会进步的核心力量。从古老的四大发明到如今的人工智能、基因编辑、量子计算等前沿技术&#xff0c;科技发展的速度日新月异。我们不禁会想&#xff0c;在…...

[python3]Uvicorn库

Uvicorn 是一个用于运行 ASGI&#xff08;Asynchronous Server Gateway Interface&#xff09;应用程序的轻量级服务器。ASGI 是 Python Web 应用程序接口的一种扩展&#xff0c;它不仅支持传统的同步 Web 请求处理&#xff0c;还支持异步请求处理、WebSockets 以及 HTTP/2。 h…...

istio-proxy oom问题排查步骤

1. 查看cluster数量 cluster数量太多会导致istio-proxy占用比较大的内存&#xff0c;此时需检查是否dr资源的host设置有配置为* 2. 查看链路数据采样率 若采样率设置过高&#xff0c;在压测时需要很大的内存来维护链路数据。可以调低采样率或增大istio-proxy内存。 检查iop中…...

Flutter:使用FVM安装多个Flutter SDK 版本和使用教程

一、FVM简介 FVM全称&#xff1a;Flutter Version Management FVM通过引用每个项目使用的Flutter SDK版本来帮助实现一致的应用程序构建。它还允许您安装多个Flutter版本&#xff0c;以快速验证和测试您的应用程序即将发布的Flutter版本&#xff0c;而无需每次等待Flutter安装。…...

关于物联网的基础知识(二)——物联网体系结构分层

成长路上不孤单&#x1f60a;&#x1f60a;&#x1f60a;&#x1f60a;&#x1f60a;&#x1f60a; 【14后&#x1f60a;///计算机爱好者&#x1f60a;///持续分享所学&#x1f60a;///如有需要欢迎收藏转发///&#x1f60a;】 今日分享关于物联网的基础知识&#xff08;二&a…...

[程序设计]—代理模式

[程序设计]—代理模式&#x1f473; 本文章记录学习于——52.面向切面&#xff1a;AOP-场景模拟_哔哩哔哩_bilibili 最近闲来无事&#xff0c;在学习Spring的源码&#xff1a; 后面慢慢更新源码系列blog&#xff0c;希望多多关注&#x1f64f;&#x1f64f; 目前已经总结的b…...

26、【OS】【Nuttx】用cmake构建工程

背景 之前wiki 14、【OS】【Nuttx】Nsh中运行第一个程序 都是用 make 构建&#xff0c;准备切换 cmake 进行构建&#xff0c;方便后续扩展开发 Nuttx cmake 适配 nuttx项目路径下输入 make distclean&#xff0c;清除之前工程配置 adminpcadminpc:~/nuttx_pdt/nuttx$ make …...

TDengine 快速体验(Docker 镜像方式)

简介 TDengine 可以通过安装包、Docker 镜像 及云服务快速体验 TDengine 的功能&#xff0c;本节首先介绍如何通过 Docker 快速体验 TDengine&#xff0c;然后介绍如何在 Docker 环境下体验 TDengine 的写入和查询功能。如果你不熟悉 Docker&#xff0c;请使用 安装包的方式快…...

css实现圆环展示百分比,根据值动态展示所占比例

代码如下 <view class""><view class"circle-chart"><view v-if"!!num" class"pie-item" :style"{background: conic-gradient(var(--one-color) 0%,#E9E6F1 ${num}%),}"></view><view v-else …...

【Oracle APEX开发小技巧12】

有如下需求&#xff1a; 有一个问题反馈页面&#xff0c;要实现在apex页面展示能直观看到反馈时间超过7天未处理的数据&#xff0c;方便管理员及时处理反馈。 我的方法&#xff1a;直接将逻辑写在SQL中&#xff0c;这样可以直接在页面展示 完整代码&#xff1a; SELECTSF.FE…...

【2025年】解决Burpsuite抓不到https包的问题

环境&#xff1a;windows11 burpsuite:2025.5 在抓取https网站时&#xff0c;burpsuite抓取不到https数据包&#xff0c;只显示&#xff1a; 解决该问题只需如下三个步骤&#xff1a; 1、浏览器中访问 http://burp 2、下载 CA certificate 证书 3、在设置--隐私与安全--…...

HashMap中的put方法执行流程(流程图)

1 put操作整体流程 HashMap 的 put 操作是其最核心的功能之一。在 JDK 1.8 及以后版本中&#xff0c;其主要逻辑封装在 putVal 这个内部方法中。整个过程大致如下&#xff1a; 初始判断与哈希计算&#xff1a; 首先&#xff0c;putVal 方法会检查当前的 table&#xff08;也就…...

保姆级教程:在无网络无显卡的Windows电脑的vscode本地部署deepseek

文章目录 1 前言2 部署流程2.1 准备工作2.2 Ollama2.2.1 使用有网络的电脑下载Ollama2.2.2 安装Ollama&#xff08;有网络的电脑&#xff09;2.2.3 安装Ollama&#xff08;无网络的电脑&#xff09;2.2.4 安装验证2.2.5 修改大模型安装位置2.2.6 下载Deepseek模型 2.3 将deepse…...

Mysql中select查询语句的执行过程

目录 1、介绍 1.1、组件介绍 1.2、Sql执行顺序 2、执行流程 2.1. 连接与认证 2.2. 查询缓存 2.3. 语法解析&#xff08;Parser&#xff09; 2.4、执行sql 1. 预处理&#xff08;Preprocessor&#xff09; 2. 查询优化器&#xff08;Optimizer&#xff09; 3. 执行器…...

[ACTF2020 新生赛]Include 1(php://filter伪协议)

题目 做法 启动靶机&#xff0c;点进去 点进去 查看URL&#xff0c;有 ?fileflag.php说明存在文件包含&#xff0c;原理是php://filter 协议 当它与包含函数结合时&#xff0c;php://filter流会被当作php文件执行。 用php://filter加编码&#xff0c;能让PHP把文件内容…...

Linux系统部署KES

1、安装准备 1.版本说明V008R006C009B0014 V008&#xff1a;是version产品的大版本。 R006&#xff1a;是release产品特性版本。 C009&#xff1a;是通用版 B0014&#xff1a;是build开发过程中的构建版本2.硬件要求 #安全版和企业版 内存&#xff1a;1GB 以上 硬盘&#xf…...

Elastic 获得 AWS 教育 ISV 合作伙伴资质,进一步增强教育解决方案产品组合

作者&#xff1a;来自 Elastic Udayasimha Theepireddy (Uday), Brian Bergholm, Marianna Jonsdottir 通过搜索 AI 和云创新推动教育领域的数字化转型。 我们非常高兴地宣布&#xff0c;Elastic 已获得 AWS 教育 ISV 合作伙伴资质。这一重要认证表明&#xff0c;Elastic 作为 …...