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;
}
相关文章
|
1天前
|
存储 算法 测试技术
ArrayList集合的两个实例应用,有趣的洗牌算法与杨辉三角
ArrayList集合的两个实例应用,有趣的洗牌算法与杨辉三角
28 1
|
1天前
|
监控 算法 安全
带用集合算法set union讲解
带用集合算法set union讲解
20 0
|
1天前
|
缓存 算法 安全
Java集合框架:深入探究数据结构与算法的精华
Java集合框架:深入探究数据结构与算法的精华
|
1天前
|
存储 算法 程序员
C++从入门到精通:2.2.1标准库与STL容器算法深度解析
C++从入门到精通:2.2.1标准库与STL容器算法深度解析
|
1天前
|
存储 算法 JavaScript
【C++ 泛型编程 入门篇】 C++ 中的泛型算法 STL(sort,find)(二)
【C++ 泛型编程 入门篇】 C++ 中的泛型算法 STL(sort,find)
35 0
|
1天前
|
算法 搜索推荐 程序员
【C++ 泛型编程 入门篇】 C++ 中的泛型算法 STL(sort,find)(一)
【C++ 泛型编程 入门篇】 C++ 中的泛型算法 STL(sort,find)
41 0
|
1天前
|
存储 算法 Java
【数据结构与算法】2、链表(简单模拟 Java 中的 LinkedList 集合,反转链表面试题)
【数据结构与算法】2、链表(简单模拟 Java 中的 LinkedList 集合,反转链表面试题)
43 0
|
1天前
|
存储 算法 搜索推荐
C++模板与STL【常用算法】
C++模板与STL【常用算法】
|
1天前
|
算法 数据安全/隐私保护 计算机视觉
基于二维CS-SCHT变换和LABS方法的水印嵌入和提取算法matlab仿真
该内容包括一个算法的运行展示和详细步骤,使用了MATLAB2022a。算法涉及水印嵌入和提取,利用LAB色彩空间可能用于隐藏水印。水印通过二维CS-SCHT变换、低频系数处理和特定解码策略来提取。代码段展示了水印置乱、图像处理(如噪声、旋转、剪切等攻击)以及水印的逆置乱和提取过程。最后,计算并保存了比特率,用于评估水印的稳健性。
|
1天前
|
算法 计算机视觉
基于高斯混合模型的视频背景提取和人员跟踪算法matlab仿真
该内容是关于使用MATLAB2013B实现基于高斯混合模型(GMM)的视频背景提取和人员跟踪算法。算法通过GMM建立背景模型,新帧与模型比较,提取前景并进行人员跟踪。文章附有程序代码示例,展示从读取视频到结果显示的流程。最后,结果保存在Result.mat文件中。