stl源码剖析 详细学习笔记 算法总览
//****************************基本算法*****************************
/*
stl算法总览,不在stl标准规格的sgi专属算法,都以 *加以标记
算法名称
算法用途 质变
所在文件
accumulate 元素累计
否 <stl_numeric.h>
adjacent_difference 相邻元素的差额
是 if in-place <stl_numeric.h>
adjacent_find 查找相邻而重复
否 <stl_algo.h>
(或符合某条件)的元素
binary_search 二分查找
否 <stl_algo.h>
Copy 复制
是 if in-place <stl_algobase.h>
Copy_backward 逆向复制
是 if in-place <stl_algobase.h>
Copy_n * 复制n个元素
是 if in-place <stl_algobase.h>
count 计数
否 <stl_algo.h>
count_if 在特定条件下计数
否 <stl_algo.h>
equal 判断两个区间是否相等
否 <stl_algobase.h>
equal_range 试图在有序区间中寻找
某值(返回一个上下限区间)
否 <stl_algo.h>
fill 改填元素值
是 <stl_algobase.h>
fill_n 改填元素值,n次
是 <stl_algobase.h>
find 循序查找
否 <stl_algo.h>
find_if 循序查找符合特定条件者
否 <stl_algo.h>
find_end 查找某个子序列的最后
否 <stl_algo.h>
一次出现点
find_first_of 查找某些元素的首次出现点
否 <stl_algo.h>
for_each 对区间内的每一个元素施行
否 <stl_algo.h>
某操作
generate 以特定操作之运算结果
是 <stl_algo.h>
填充特定区间内的元素
generate_n 以特定操作之运算结果
是 <stl_algo.h>
填充n个元素
includes 是否涵盖于某序列之中
否 <stl_algo.h>
inner_product 内积
否 <stl_numeric.h>
inplace_merge 合并并就地替换(复写上去)
是 <stl_algo.h>
iota * 在某区间填入某指定值的
是 <stl_numeric.h>
递增序列
is_heap * 判断某区间是否为一个heap
否 <stl_algo.h>
is_sorted * 判断某区间是否已排序
否 <stl_algo.h>
iter_swap 元素互换
是 <stl_algobase.h>
lexicograpghical_ 以字典顺序进行比较
否 <stl_numeric.h>
compare
lower_bound 将指定元素插入区间之内
否 <stl_algo.h>
而不影响区间之原本排序的最低位置
max 最大值
否 <stl_algobase.h>
max_element 最大值所在位置
否 <stl_algo.h>
merge 合并两个序列
是 if in-place <stl_algo.h>
min 最小值
否 <stl_algobase.h>
min_element 最小值所在位置
否 <stl_algo.h>
mismatch 找出不匹配点
否 <stl_algobase.h>
next_permutation 获得下一个排列组合
是 <stl_algo.h>
nth_element 重新安排序列中的第n个
是 <stl_algo.h>
元素的左右两端
partial_sort 局部排序
是 <stl_algo.h>
partial_sort_copy 局部排序并复制到他处
是 if in-place <stl_algo.h>
partial_sum 局部求和
是 if in-place <stl_numeric.h>
partition 分割
是 <stl_algo.h>
prev_permutation 获得前一个排列组合
是 <stl_algo.h>
power * 幂次方。表达式可指定
否 <stl_numeric.h>
random_suffle 随即重排元素
是 <stl_algo.h>
random_sample * 随即取样
是 if in-place <stl_algo.h>
random_sample_n * 随即取样
是 if in-place <stl_algo.h>
remove 删除某类元素(但不删除)
是 <stl_algo.h>
remove_copy 删除某类元素并将结果
是 <stl_algo.h>
复制到另一个容器
remove_if 有条件地删除某类元素
是 <stl_algo.h>
remove_copy_if 有条件地删除某类元素并将
是 <stl_algo.h>
结果复制到另一个容器
replace 替换某类元素
是 <stl_algo.h>
replace_copy 替换某类元素,并将结果
是 <stl_algo.h>
复制到另一个容器
replace_if 有条件地替换
是 <stl_algo.h>
replace_copy_if 有条件地替换,并将结果
是 <stl_algo.h>
复制到另一个容器
reverse 反转元素次序
是 <stl_algo.h>
reverse_copy 反转元素次序并将结果
是 <stl_algo.h>
复制到另一个容器
rotate 旋转
是 <stl_algo.h>
rotate_copy 旋转,并将结果复制到
是 <stl_algo.h>
另一个容器
search 查找某个子序列
否 <stl_algo.h>
search_n 查找连续发生n次的子序列
否 <stl_algo.h>
set_difference 差集
是 if in-place <stl_algo.h>
set_intersection 交集
是 if in-place <stl_algo.h>
set_symmetric_ 对称差集
是 if in-place <stl_algo.h>
difference
set_union 并集
是 if in-place <stl_algo.h>
sort 排序
是 <stl_algo.h>
stable_partition 分割并保持元素的相对次序
是 <stl_algo.h>
stable_sort 排序并保持等值元素的
是 <stl_algo.h>
相对次序
swap 交换(对调)
是 <stl_algobase.h>
swap_ranges 交换(指定区间)
是 <stl_algo.h>
transform 以两个序列为基础,交互
是 <stl_algo.h>
作用产生第三个序列
unique 将重复的元素折叠缩编,
是 <stl_algo.h>
使成唯一
unique_copy 将重复的元素折叠缩编,
是 if in-place <stl_algo.h>
使成唯一,并复制到他处
upper_bound 将指定元素插入区间之内
否 <stl_algo.h>
而不影响区间之原本排序
的最高位置
make_heap 制造一个heap
是 <stl_heap.h>
pop_heap 从heap取出一个元素
是 <stl_heap.h>
push_heap 将元素推进heap内
是 <stl_heap.h>
sort_heap 对heap排序
是 <stl_heap.h>
*/
stl源码剖析 详细学习笔记 算法总览的更多相关文章
- stl源码剖析 详细学习笔记 算法(1)
//---------------------------15/03/27---------------------------- //算法 { /* 质变算法:会改变操作对象之值 所有的stl算法都 ...
- stl源码剖析 详细学习笔记 算法(2)
//---------------------------15/03/29---------------------------- //****************************set相 ...
- stl源码剖析 详细学习笔记 算法(5)
//---------------------------15/04/01---------------------------- //inplace_merge(要求有序) template< ...
- stl源码剖析 详细学习笔记 算法(4)
//---------------------------15/03/31---------------------------- //lower_bound(要求有序) template<cl ...
- stl源码剖析 详细学习笔记 算法(3)
//---------------------------15/03/30---------------------------- //min_element template<class Fo ...
- stl源码剖析 详细学习笔记 hashtable
//---------------------------15/03/24---------------------------- //hashtable { /* 概述: sgi采用的是开链法完成h ...
- stl源码剖析 详细学习笔记 set map
// // set map.cpp // 笔记 // // Created by fam on 15/3/23. // // //---------------------------15/03 ...
- stl源码剖析 详细学习笔记 RB_tree (2)
//---------------------------15/03/22---------------------------- //一直好奇KeyOfValue是什么,查了下就是一个和仿函数差不多 ...
- stl源码剖析 详细学习笔记 RB_tree (1)
// // RB_tree_STL.cpp // 笔记 // // Created by fam on 15/3/21. // // #include "RB_tree_STL.h&q ...
随机推荐
- sql server 日期时间与字符串的转换
一.sql server日期时间函数Sql Server中的日期与时间函数 1. 当前系统日期.时间 select getdate() 2. dateadd 在向指定日期加上一段时间的基 ...
- T-SQL检查停止的复制作业代理,并启动 (转载)
有时候搭建的复制在作业比较多的时候,会因为某些情况导致代理停止或出错,如果分发代理时间停止稍微过长可能导致复制延期,从而需要从新初始化复制,带来问题.因此我写了一个脚本定期检查处于停止状态的分发代理, ...
- 十个强大的DevOps基础设施自动化工具,不容错过
Devops基础设施自动化的工具 有许多工具用于基础设施自动化.使用哪个工具决定于体系结构和基础设施的需求.下面我们列出了一些伟大的工具,用于不同类别配置管理.编制.持续集成.监控等. 1.Chef ...
- tomcat8.5 Host-Manager配置访问的方法
1. 安装配置tomcat服务器,浏览器输入 localhost:8080,可正常访问主页,但访问localhost:8080/host-manager, localhost:8080/manager ...
- Go语言学习笔记(六)net & net/http
加 Golang学习 QQ群共同学习进步成家立业工作 ^-^ 群号:96933959 net import "net" net包提供了可移植的网络I/O接口,包括TCP/IP.UD ...
- MySQL主从复制半同步复制原理及搭建
在MySQL5.5之前的版本中,MySQL的复制是异步复制,主库和从库的数据之间存在一定的延迟,比如网络故障等各种原因,这样子容易存在隐患就是:当在主库写入一个事务成功后并提交了,但是由于从库延迟没有 ...
- react的新手基础知识笔记
<!DOCTYPE html> <html> <head> <script src="../build/react.js">< ...
- SQL Server:INFORMATION_SCHEMA.columns 与sys.columns 与 syscolumns对比
sys.columns视图 sys.columns是SQL Server从2005版本起引入的新的系统级视图.相关链接如下: Mapping SQL Server 2000 System Tables ...
- 【2017下集美大学软工1412班_助教博客】个人作业2——APP案例分析
作业要求 个人作业2:APP案例分析 评分结果 按从高到低排列 学号后三位 第二次作业 Total 008 APP案例分析 23 044 第2次作业 19.5 011 App案例分析--XBMC 19 ...
- python第四十一课——析构函数
3.析构函数 格式:__del__(self): 作用: 在程序结束前将对象回收,释放资源的行为 演示析构函数的使用: class Animal: #定义构造函数 def __init__(self, ...