博客
关于我
实用的 s t l
阅读量:575 次
发布时间:2019-03-11

本文共 760 字,大约阅读时间需要 2 分钟。

寻找数组中的最大最小值可以通过C++ STL中的标准函数实现。对于找出最大值和最小值,使用min_elementmax_element函数即可。这些函数的时间复杂度均为O(n),适用于任意长度的数组。

为了将第n小的数放到对应的位置,可以使用nth_element函数。这一操作的时间复杂度同样为O(n),适合直接在排序后的数组中进行。

如果你的数组当前是未排序的,想要进行排序操作和反转,可以使用sort函数将数组排序,然后再调用reverse函数进行反转,操作时间复杂度为O(n log n)。

如果你已经有一个排序好的数组,可以使用unique函数来扫描数组并去除重复的元素,并返回新的终止指针,这样就能得到一个仅包含唯一元素的新数组。

要检查某个元素是否存在于数组中,可以使用binary_search函数进行二分查找,返回一个布尔值,判断元素是否存在。这种方法的时间复杂度为O(logn)。

如果你希望找到某个元素在数组中的存在位置,可以使用lower_bound函数,它会返回第一个大于或等于指定元素的位置,或者在数组末尾返回end指针。如果你需要找到第一个大于指定元素的位置,可以使用upper_bound函数。

需要注意的是,lower_boundupper_bound的查找范围都是在数组的begin到end-1位置,这样可以避免越界问题。

除此之外,C++ STL还提供了多种容器,如stack(栈,先进后出),queue(队列,先进先出),以及priority_queue(优先队列,基于优先级进行排序)。例如,stack

que可以实现栈操作,如push和pop,队列可以使用push和front方法实现先进先出的功能,优先队列则可以通过push和top()方法来管理和获取具有优先级的元素。

转载地址:http://rqrvz.baihongyu.com/

你可能感兴趣的文章
上周热点回顾(1.23-1.29)
查看>>
83. Remove Duplicates from Sorted List
查看>>
Oracle Orion tool check io(ORACLE Orion 工具查看以及校验IO)
查看>>
centos7一步一步搭建docker jenkins 及自定义访问路径重点讲解
查看>>
MySQL 1064 You have an error in your SQL syntax 错误解决办法
查看>>
【Flink】Flink 底层RPC框架分析
查看>>
MySQL错误日志(Error Log)
查看>>
C++高精度模板
查看>>
解决:angularjs radio默认选中失效问题
查看>>
windows环境下安装zookeeper(仅本地使用)
查看>>
缓冲区溢出实例(一)--Windows
查看>>
PHP一句话木马小总结与SQL语句写一句话木马
查看>>
Python中字符串前添加r ,b, u, f前缀的含义
查看>>
Hadoop学习笔记—Yarn
查看>>
JSONPath小试牛刀之Snack3
查看>>
Jenkins - 部署在Tomcat容器里的Jenkins,提示“反向代理设置有误”
查看>>
wxWidgets源码分析(3) - 消息映射表
查看>>
wxWidgets源码分析(5) - 窗口管理
查看>>
wxWidgets源码分析(7) - 窗口尺寸
查看>>
wxWidgets源码分析(8) - MVC架构
查看>>