【C++常用算法】STL基础语法学习 | 排序算法

简介: 对容器内元素进行排序

●sort


1.功能描述:


       对容器内元素进行排序


2.查看sort定义下底层代码的函数原型:

2bcd2fddda02942f17fdc9f086b5dcc4_b9dca121893a4170a26509ae56fb2071.png

3.向vector容器中插入10个无序数,并且用sort排序法对其进行升序和降序(内建仿函数greater<数据类型>())的排序。

001af3b36eedae0aa205a3ef2bb884e0_c6ac90fb86c14c07b4abfb687663a70d.png

greater<数据类型>()

#include<iostream>
#include<vector>
#include<algorithm>  //算法头文件 
#include<functional>  //内建仿函数头文件
using namespace std;
void printvector(int value)
{
  cout << value << " ";
}
void text()
{
  vector<int>v;
  int n;
  cout << "请向vector容器中插入10个无序数:";
  for (int i = 1; i <= 10; i++)
  {
  cin >> n;
  v.push_back(n);
  }
  cout << "sort的升序排序" << endl;
  sort(v.begin(),v.end());
  for_each(v.begin(), v.end(),printvector);
  cout << endl;
  cout << "sort的降序排序" << endl;
  sort(v.begin(), v.end(), greater<int>()); 
  for_each(v.begin(),v.end(),printvector);
}
int main()
{
  text();
}

bdf6ad7566efdf316a612e5b434c67a8_5ef7e4579b694ecfa6d250f89dbbe85d.png


●random_shuffle


1.功能描述:


       对指定范围内的元素去随机调整顺序


2.查看random_shuffle定义下底层代码的函数原型:


e62dce6eda9a85d7c737e7c5bd143991_6c536a78a2e14decadd32ddbfeee807b.png

3.向vector容器中插入10个顺序数,用rand_shuffle洗牌算法将这10个顺序数打乱输出。


#include<iostream>
#include<vector>
#include<algorithm>
using namespace std;
void printvector(int value)
{
  cout << value << " ";
}
void text()
{
  vector<int>v;
  int n;
  cout << "请向vector容器中插入10个顺序数:";
  for (int i = 1; i <= 10; i++)
  {
  cin >> n;
  v.push_back(n);
  }
  cout << "输出这10个顺序数:";
  for_each(v.begin(),v.end(),printvector);
  cout << endl;
  cout << "输出调整乱序后的10个数:";
  random_shuffle(v.begin(), v.end());
  for_each(v.begin(), v.end(), printvector);
  cout << endl;
}
int main()
{
  text();
}

9b26c267f563da40910b9966a19604ee_ad8188ebb41149e8bfc82cc4dab4b1b1.png


● merge


1.功能描述:


       两个有序容器的合并,并且存储到另一指定容器中,合并后指定容器中的序列也是有序的


2.查看merge定义下底层代码的函数原型:

b6d12257a11fa41c315d6559fccf13e7_ad1788fa72e74cc386ce6e7bf072861a.png

3.向v1容器中插入1~10,v2容器中插入11~20。将两容器使用merge算法合并到指定容器v中并输出。

#include<iostream>
#include<vector>
#include<algorithm>
using namespace std;
void printvector(int value)
{
  cout << value << " ";
}
void text()
{
  vector<int>v1;
  vector<int>v2;
  for (int k = 1,i=1,j=11; k <= 10; k++,i++,j++)
  {
  v1.push_back(i);
  v2.push_back(j);
  }
  //1 2 3 4 5 6 7 8 9 10  [v1]
  //11 12 13 14 15 16 17 18 19 20  [v2]
  cout << "输出v1容器:";
  for_each(v1.begin(), v1.end(), printvector);
  cout << endl;
  cout << "输出v2容器:";
  for_each(v2.begin(), v2.end(), printvector);
  cout << endl;
  cout << "两容器合并后,指定容器v为:" << endl;
  vector<int>v;  //指定容器
  v.resize(v1.size()+v2.size());  //给指定容器一个空间大小
  merge(v1.begin(), v1.end(), v2.begin(), v2.end(), v.begin());
  for_each(v.begin(), v.end(), printvector);
}
int main()
{
  text();
}

7897c544e9f73d1e91267e7c0f05bd8e_84697b627d93462f828c5abd62ddec06.png


●reverse


1.功能描述:


       将容器内元素进行反转


2.查看reverse定义下底层代码的函数原型:

d7e4cb71f959940ba768adb881adf4c3_3041e814146243caa5a55ac573c22a6a.png

3.使用reverse算法去反转v1容器中1~9到v2容器中并输出。

#include<iostream>
#include<vector>
#include<algorithm>
using namespace std;
void printvector(int value)
{
  cout << value << " ";
}
void text()
{ 
  vector<int>v;
  for (int i = 1; i <= 10; i++)
  {
  v.push_back(i);
  }
  cout << "反转前:" << endl;
  for_each(v.begin(),v.end(),printvector);
  cout << endl;
  cout << "反转后:" << endl;
  reverse(v.begin(), v.end());
  for_each(v.begin(), v.end(), printvector);
}
int main()
{
  text();
}

b5c8a5fa328a1bf81cc1efa04d875158_3d83a9d84f6c49eabd6e8f85af2e0b2d.png

目录
相关文章
|
1月前
|
负载均衡 算法 安全
探秘:基于 C++ 的局域网电脑控制软件自适应指令分发算法
在现代企业信息化架构中,局域网电脑控制软件如同“指挥官”,通过自适应指令分发算法动态调整指令发送节奏与数据量,确保不同性能的终端设备高效运行。基于C++语言,利用套接字实现稳定连接和线程同步管理,结合实时状态反馈,优化指令分发策略,提升整体管控效率,保障网络稳定,助力数字化办公。
52 19
|
1月前
|
C++ 开发者
C++学习之继承
通过继承,C++可以实现代码重用、扩展类的功能并支持多态性。理解继承的类型、重写与重载、多重继承及其相关问题,对于掌握C++面向对象编程至关重要。希望本文能为您的C++学习和开发提供实用的指导。
58 16
|
2月前
|
算法 网络安全 区块链
2023/11/10学习记录-C/C++对称分组加密DES
本文介绍了对称分组加密的常见算法(如DES、3DES、AES和国密SM4)及其应用场景,包括文件和视频加密、比特币私钥加密、消息和配置项加密及SSL通信加密。文章还详细展示了如何使用异或实现一个简易的对称加密算法,并通过示例代码演示了DES算法在ECB和CBC模式下的加密和解密过程,以及如何封装DES实现CBC和ECB的PKCS7Padding分块填充。
67 4
2023/11/10学习记录-C/C++对称分组加密DES
|
1月前
|
存储 算法 测试技术
【C++数据结构——树】二叉树的遍历算法(头歌教学实验平台习题) 【合集】
本任务旨在实现二叉树的遍历,包括先序、中序、后序和层次遍历。首先介绍了二叉树的基本概念与结构定义,并通过C++代码示例展示了如何定义二叉树节点及构建二叉树。接着详细讲解了四种遍历方法的递归实现逻辑,以及层次遍历中队列的应用。最后提供了测试用例和预期输出,确保代码正确性。通过这些内容,帮助读者理解并掌握二叉树遍历的核心思想与实现技巧。
49 2
|
2月前
|
存储 算法 安全
基于红黑树的局域网上网行为控制C++ 算法解析
在当今网络环境中,局域网上网行为控制对企业和学校至关重要。本文探讨了一种基于红黑树数据结构的高效算法,用于管理用户的上网行为,如IP地址、上网时长、访问网站类别和流量使用情况。通过红黑树的自平衡特性,确保了高效的查找、插入和删除操作。文中提供了C++代码示例,展示了如何实现该算法,并强调其在网络管理中的应用价值。
|
1月前
|
存储 算法 安全
基于哈希表的文件共享平台 C++ 算法实现与分析
在数字化时代,文件共享平台不可或缺。本文探讨哈希表在文件共享中的应用,包括原理、优势及C++实现。哈希表通过键值对快速访问文件元数据(如文件名、大小、位置等),查找时间复杂度为O(1),显著提升查找速度和用户体验。代码示例展示了文件上传和搜索功能,实际应用中需解决哈希冲突、动态扩容和线程安全等问题,以优化性能。
|
2月前
|
算法 安全 C++
用 C++ 算法控制员工上网的软件,关键逻辑是啥?来深度解读下
在企业信息化管理中,控制员工上网的软件成为保障网络秩序与提升办公效率的关键工具。该软件基于C++语言,融合红黑树、令牌桶和滑动窗口等算法,实现网址精准过滤、流量均衡分配及异常连接监测。通过高效的数据结构与算法设计,确保企业网络资源优化配置与安全防护升级,同时尊重员工权益,助力企业数字化发展。
65 4
|
4月前
|
编译器 C语言 C++
配置C++的学习环境
【10月更文挑战第18天】如果想要学习C++语言,那就需要配置必要的环境和相关的软件,才可以帮助自己更好的掌握语法知识。 一、本地环境设置 如果您想要设置 C++ 语言环境,您需要确保电脑上有以下两款可用的软件,文本编辑器和 C++ 编译器。 二、文本编辑器 通过编辑器创建的文件通常称为源文件,源文件包含程序源代码。 C++ 程序的源文件通常使用扩展名 .cpp、.cp 或 .c。 在开始编程之前,请确保您有一个文本编辑器,且有足够的经验来编写一个计算机程序,然后把它保存在一个文件中,编译并执行它。 Visual Studio Code:虽然它是一个通用的文本编辑器,但它有很多插
|
4月前
|
算法 数据处理 C++
c++ STL划分算法;partition()、partition_copy()、stable_partition()、partition_point()详解
这些算法是C++ STL中处理和组织数据的强大工具,能够高效地实现复杂的数据处理逻辑。理解它们的差异和应用场景,将有助于编写更加高效和清晰的C++代码。
90 0
|
4月前
|
机器学习/深度学习 搜索推荐 算法
探索数据结构:初入算法之经典排序算法
探索数据结构:初入算法之经典排序算法