STL常用算数生成与常用集合算法

简介: STL常用算数生成与常用集合算法

全部案例链接


https://download.csdn.net/download/weixin_45525272/12536637



常用算数生成算法


accumulate算法 计算容器元素累计总和
  @param beg 容器开始迭代器
  @param end 容器结束迭代器
  @param value累加值
accumulate(iterator beg, iterator end, value)
fill算法 向容器中添加元素
  @param beg 容器开始迭代器
  @param end 容器结束迭代器
  @param value t填充元素
fill(iterator beg, iterator end, value)


案例1


#define _CRT_SECURE_NO_WARNINGS
#include<iostream>
#include <vector>
using namespace std;
#include <algorithm> //不好使
#include <numeric> //好使
#include <iterator>
/*
accumulate算法 计算容器元素累计总和
@param beg 容器开始迭代器
@param end 容器结束迭代器
@param value累加值
*/
void test01()
{
  vector<int>v;
  for (int i = 0; i <= 100;i++)
  {
    v.push_back(i);
  }
  //0~100累积和  5050
  //第三个参数  起始累加值
  int sum = accumulate(v.begin(), v.end(), 0);
  cout << "总和为:" << sum << endl;
}
/*
fill算法 向容器中添加元素
@param beg 容器开始迭代器
@param end 容器结束迭代器
@param value t填充元素
*/
void test02()
{
  vector<int>v;
  v.resize(10);
  fill(v.begin(), v.end(), 1000);
  copy(v.begin(), v.end(), ostream_iterator<int>(cout, " "));
}
int main(){
  //test01();
  test02();
  system("pause");
  return EXIT_SUCCESS;
}


常用集合算法


set_intersection算法 求两个set集合的交集
注意:两个集合必须是有序序列
  @param beg1 容器1开始迭代器
  @param end1 容器1结束迭代器
  @param beg2 容器2开始迭代器
  @param end2 容器2结束迭代器
  @param dest  目标容器开始迭代器
  @return 目标容器的最后一个元素的迭代器地址
set_intersection(iterator beg1, iterator end1, iterator beg2, iterator end2, iterator dest)
set_union算法 求两个set集合的并集
注意:两个集合必须是有序序列
  @param beg1 容器1开始迭代器
  @param end1 容器1结束迭代器
  @param beg2 容器2开始迭代器
  @param end2 容器2结束迭代器
  @param dest  目标容器开始迭代器
  @return 目标容器的最后一个元素的迭代器地址
*/
set_union(iterator beg1, iterator end1, iterator beg2, iterator end2, iterator dest)
set_difference算法 求两个set集合的差集
注意:两个集合必须是有序序列
  @param beg1 容器1开始迭代器
  @param end1 容器1结束迭代器
  @param beg2 容器2开始迭代器
  @param end2 容器2结束迭代器
  @param dest  目标容器开始迭代器
  @return 目标容器的最后一个元素的迭代器地址
set_difference(iterator beg1, iterator end1, iterator beg2, iterator end2, iterator dest)


案例2


#define _CRT_SECURE_NO_WARNINGS
#include<iostream>
#include <algorithm>
#include <vector>
#include <iterator>
using namespace std;
/*
set_intersection算法 求两个set集合的交集
注意:两个集合必须是有序序列
@param beg1 容器1开始迭代器
@param end1 容器1结束迭代器
@param beg2 容器2开始迭代器
@param end2 容器2结束迭代器
@param dest  目标容器开始迭代器
@return 目标容器的最后一个元素的迭代器地址
*/
void test01()
{
  vector<int>v1;
  vector<int>v2;
  for (int i = 0; i < 10;i++)
  {
    v1.push_back(i);
    v2.push_back(i + 5);
  }
  vector<int> vTarget;
  vTarget.resize( min(v1.size(),v2.size()));
  vector<int>::iterator itEnd= set_intersection(v1.begin(), v1.end(), v2.begin(), v2.end(), vTarget.begin());
  copy(vTarget.begin(), itEnd, ostream_iterator<int>(cout, " "));
}
/*
set_union算法 求两个set集合的并集
注意:两个集合必须是有序序列
@param beg1 容器1开始迭代器
@param end1 容器1结束迭代器
@param beg2 容器2开始迭代器
@param end2 容器2结束迭代器
@param dest  目标容器开始迭代器
@return 目标容器的最后一个元素的迭代器地址
*/
void test02()
{
  vector<int>v1;
  vector<int>v2;
  for (int i = 0; i < 10; i++)
  {
    v1.push_back(i);
    v2.push_back(i + 5);
  }
  vector<int> vTarget;
  vTarget.resize(v1.size()+v2.size());
  vector<int>::iterator itEnd = set_union(v1.begin(), v1.end(), v2.begin(), v2.end(), vTarget.begin());
  copy(vTarget.begin(), itEnd, ostream_iterator<int>(cout, " "));
}
/*
set_difference算法 求两个set集合的差集
注意:两个集合必须是有序序列
@param beg1 容器1开始迭代器
@param end1 容器1结束迭代器
@param beg2 容器2开始迭代器
@param end2 容器2结束迭代器
@param dest  目标容器开始迭代器
@return 目标容器的最后一个元素的迭代器地址
*/
void test03()
{
  vector<int>v1;
  vector<int>v2;
  for (int i = 0; i < 10; i++)
  {
    v1.push_back(i);
    v2.push_back(i + 5);
  }
  vector<int> vTarget;
  vTarget.resize( max(v1.size(),v2.size() ));
  //v1差v2
  vector<int>::iterator itEnd = set_difference(v1.begin(), v1.end(), v2.begin(), v2.end(), vTarget.begin());
  copy(vTarget.begin(), itEnd, ostream_iterator<int>(cout, " "));
  cout << endl;
  //v2 差 v1
  itEnd = set_difference(v2.begin(), v2.end(), v1.begin(), v1.end(), vTarget.begin());
  copy(vTarget.begin(), itEnd, ostream_iterator<int>(cout, " "));
}
int main(){
  //test01();
  //test02();
  test03();
  system("pause");
  return EXIT_SUCCESS;
}
相关文章
|
4月前
|
算法 数据处理 C++
c++ STL划分算法;partition()、partition_copy()、stable_partition()、partition_point()详解
这些算法是C++ STL中处理和组织数据的强大工具,能够高效地实现复杂的数据处理逻辑。理解它们的差异和应用场景,将有助于编写更加高效和清晰的C++代码。
90 0
|
6月前
|
算法
突击面试:解密面试官的算法题集合
突击面试:解密面试官的算法题集合
|
7月前
|
算法 C++
STL算法大全
以上只是一部分STL算法的简单概述,每一个算法都有其特定的使用场景和规则,具体使用时需要参考相关文档或者教程进行深入理解和学习。
48 0
|
8月前
|
算法 Java
Java数据结构与算法:用于处理不相交集合的合并和查找问题
Java数据结构与算法:用于处理不相交集合的合并和查找问题
|
8月前
|
算法 搜索推荐 C++
C++之STL常用算法(遍历、查找、排序、拷贝、替换、算数生成、集合)
C++之STL常用算法(遍历、查找、排序、拷贝、替换、算数生成、集合)
|
8月前
|
算法 前端开发 Linux
【常用技巧】C++ STL容器操作:6种常用场景算法
STL在Linux C++中使用的非常普遍,掌握并合适的使用各种容器至关重要!
123 10
|
9月前
|
算法 C++
c++算法学习笔记 (21) STL
c++算法学习笔记 (21) STL
|
9月前
|
算法 C++ 容器
黑马c++ STL常用算法 笔记(6) 常用集合算法
黑马c++ STL常用算法 笔记(6) 常用集合算法
|
1天前
|
传感器 算法
基于GA遗传算法的多机无源定位系统GDOP优化matlab仿真
本项目基于遗传算法(GA)优化多机无源定位系统的GDOP,使用MATLAB2022A进行仿真。通过遗传算法的选择、交叉和变异操作,迭代优化传感器配置,最小化GDOP值,提高定位精度。仿真输出包括GDOP优化结果、遗传算法收敛曲线及三维空间坐标点分布图。核心程序实现了染色体编码、适应度评估、遗传操作等关键步骤,最终展示优化后的传感器布局及其性能。
|
2天前
|
机器学习/深度学习 算法 安全
基于深度学习的路面裂缝检测算法matlab仿真
本项目基于YOLOv2算法实现高效的路面裂缝检测,使用Matlab 2022a开发。完整程序运行效果无水印,核心代码配有详细中文注释及操作视频。通过深度学习技术,将目标检测转化为回归问题,直接预测裂缝位置和类别,大幅提升检测效率与准确性。适用于实时检测任务,确保道路安全维护。 简介涵盖了算法理论、数据集准备、网络训练及检测过程,采用Darknet-19卷积神经网络结构,结合随机梯度下降算法进行训练。

热门文章

最新文章