Effective STL

<algorithm>

2018-02-06  本文已影响16人  downdemo

*标注为C++11/14引入,范围为[first,last)

Non-modifying sequence operations

函数名 功能 形式 f
*all_of 检查范围内是否所有元素满足给定条件,返回一个bool all_of(v.begin(), v.end(), f) bool f(int i);f也可以是一个lambda
*any_of 检查范围内是否存在元素满足给定条件,返回一个bool any_of(v.begin(), v.end(), f) bool f(int i);f也可以是一个lambda
*none_of 检查范围内是否所有元素不满足给定条件,返回一个bool none_of(v.begin(), v.end(), f) bool f(int i);f也可以是一个lambda
for_each 遍历范围内元素,传给f执行 for_each(v.begin(), v.end(), f) void f(int i);f也可以是一个只有void operator()(int i){}的类对象
find 查找范围内是否存在30,若存在则返回第一个对应迭代器,否则返回尾迭代器 find(v.begin(), v.end(), 30)
find_if 查找范围内是否存在满足给定条件的元素,若存在则返回第一个对应迭代器,否则返回尾迭代器 find_if(v.begin(), v.end(), f) bool f(int i)
*find_if_not 查找范围内是否存在不满足给定条件的元素,若存在则返回第一个对应迭代器,否则返回尾迭代器 find_if_not(v.begin(), v.end(), f) bool f(int i)
find_end 范围2为范围1的最后的子序列,返回范围2首元素在范围1中的对应的迭代器,若未找到则返回范围1的尾迭代器,参数可以多一个自定义条件f find_end(v.begin(), v.end(), sub.begin(), sub.end(), f) bool f(int i, int j)
find_first_of 范围2为范围1的第一个子序列,返回范围2首元素在范围1中的对应的迭代器,若未找到则返回范围1的尾迭代器,参数可以多一个自定义条件f find_first_of(v.begin(), v.end(), sub.begin(), sub.end(), f) bool f(int i, int j)
adjacent_find 查找第一对相邻且相同的元素,返回后一个元素的迭代器,若未找到则返回尾迭代器,参数可以多一个自定义条件f adjacent_find(v.begin(), v.end(), f) bool f(int i, int j)
count 返回值为范围内30出现的次数 count(v.begin(), v.end(), 30)
count_if 返回范围内满足给定条件的元素出现的次数 count_if(v.begin(), v.end(), f) bool f(int i)
mismatch 返回范围内不匹配给定数组的两个不同的值组成的pair,参数可以多一个自定义条件f。如果都相同则内存溢出 mismatch(v.begin(), v.end(), arr, f) bool f(int i, int j)
equal 查找范围内的元素是否与数组完全相同,返回一个bool,参数可以多一个自定义条件f。如果元素数量不同则内存溢出 equal(v.begin(), v.end(), arr, f) bool f(int i, int j)
*is_permutation 查找范围内是否含有相同的元素,顺序和数量可以不同 is_permutation(v.begin(), v.end(), arr)
search 范围2为范围1的第一个子序列,返回范围2首元素在范围1中的对应的迭代器,若未找到则返回范围1的尾迭代器,参数可以多一个自定义条件f search(v.begin(), v.end(), sub.begin(), sub.end(), f) bool f(int i, int j)
search_n 查找范围内出现2个连续的30的的第一个30对应的迭代器,未找到则返回尾迭代器,参数可以多一个自定义条件f search_n(v.begin(), v.end(), 2, 30, f) bool f(int i, int j)

Modifying sequence operations

函数名 功能 形式 f
copy 把范围1的内容拷贝到设置好size的v中 copy(arr, arr+7, v.begin())
*copy_n 把arr的7个元素拷贝到设置好size的v中 copy_n(arr, 7, v.begin())
*copy_if 把满足条件的v中元素拷贝到b中,返回目标范围的尾迭代器 copy_if (v.begin(), v.end(), b.begin(), f) bool f(int i)
copy_backforward 把范围内元素逆序从后往前拷贝 copy_backward(v.begin(), v.begin()+5, v.end())
*move 把范围1的元素移动到bar中,或直接move整个容器 move(v.begin(), v.begin()+4, bar.begin());foo = std::move(bar)
*move_backforward 把范围1的元素逆序从后往前移动 move_backward (elems,elems+4,elems+5)
swap 交换元素或容器的全部内容 swap(x, y);swap(foo, bar)
swap_ranges 将范围1内的元素和bar对应数量的元素交换 swap_ranges(foo.begin()+1, foo.end()-1, bar.begin())
iter_swap 交换两个迭代器的元素 iter_swap(arr+1,v.begin()+2)
transform 对foo所有元素进行op_increase操作,拷贝到bar transform (foo.begin(), foo.end(), bar.begin(), op_increase);transform (foo.begin(), foo.end(), bar.begin(), foo.begin(), std::plus<int>())
replace 把范围内的20换成99 replace(v.begin(), v.end(), 20, 99)
replace_if 把范围内满足条件的元素换成0 replace_if(v.begin(), v.end(), f, 0) bool f(int i)
replace_copy 把范围中的20以99拷贝到v(范围元素不变) replace_copy(arr, arr+8, v.begin(), 20, 99)
replace_copy_if 把范围内满足条件的元素以0拷贝到bar replace_copy_if (foo.begin(), foo.end(), bar.begin(), f, 0) bool f(int i)
fill 把范围内元素换成5 fill(v.begin(),v.begin()+4,5)
fill_n 把4个20拷贝到对应位置 fill_n(v.begin()+3,4,20)
generate 将f的执行结果拷贝到范围内 generate(v.begin(), v.end(), f) int f() { return (std::rand()%100); }
generate_n 将f的执行结果拷贝到指定位置开始的n个元素中 generate_n (arr, 9, f) int f()
remove 将范围内的20删除 remove(v.begin(), v.end(), 20)
remove_if 将范围内满足条件的元素删除 remove_if (v.begin(), v.end(), f) bool f(int i)
remove_copy 将范围内的20删除拷贝到v(范围元素不变) remove_copy (arr,arr+8,v.begin(),20)
remove_copy_if 将范围内满足条件的元素删除拷贝到v remove_copy_if (arr,arr+9,v.begin(),f) bool f(int i)
unique 去除重复元素,也可以自定义判断条件 unique(v.begin(), v.end());unique(v.begin(), v.end(),f) 默认为bool f(int i, int j) { return (i==j); }
unique_copy 去除范围内的重复元素拷贝到v,可以自定义判断条件 unique_copy(arr,arr+9,v.begin());unique_copy(arr,arr+9,v.begin(),f) 默认为bool f(int i, int j) { return (i==j); }
reverse 反转范围内元素 reverse(v.begin(),v.end())
reverse_copy 将反转的范围内元素拷贝到v reverse_copy(arr, arr+9, v.begin())
rotate 交换[first,middle)和[middle,last)两个范围内元素 rotate(v.begin(),v.begin()+3,v.end())
rotate_copy 将交换的结果拷贝到v rotate_copy(arr,arr+3,arr+7,v.begin())
random_shuffle 随机打乱范围内元素位置 random_shuffle(v.begin(),v.end());random_shuffle(v.begin(),v.end(), f) int f(int i) { return std::rand()%i;}
*shuffle 用随机数引擎打乱范围内元素位置 unsigned seed = std::chrono::system_clock::now().time_since_epoch().count();shuffle(v.begin(), v.end(), std::default_random_engine(seed));

Partitions

函数名 功能 形式 f
*is_partitioned 检测范围是否按条件划分,返回一个bool is_partitioned(v.begin(),v.end(),f) bool f(int i)
partition 按条件划分范围,返回划分边界的迭代器,不保持元素初始相对位置 partition(v.begin(), v.end(), f) bool f(int i)
stable_partition 按条件划分,返回划分边界的迭代器,保持初始位置 stable_partition(v.begin(), v.end(), f) bool f(int i)
*partition_copy 范围内满足条件的划分到两个新容器内 partition_copy(v.begin(), v.end(), odd.begin(), even.begin(), IsOdd)
*partition_point 返回第一个不满足条件的迭代器,不存在则返回尾迭代器 partition_point(v.begin(),v.end(),IsOdd)

Sorting

函数名 功能 形式 f
sort 排序,默认用<排序,可以自定义条件 sort(v.begin(), v.end());sort(v.begin(), v.end(), f) bool f(int i,int j) { return (i<j); };struct myclass { bool operator()(int i,int j) { return (i<j);} } f;
stable_sort 稳定排序 同上 bool f(double i,double j){ return (int(i)<int(j)); }
partial_sort 前5个最小的元素从小到大排序,剩下的未排序 partial_sort(v.begin(), v.begin()+5, v.end());partial_sort(v.begin(), v.begin()+5, v.end(), f) bool f(int i,int j) { return (i<j); }
partial_sort_copy 把部分排序的结果拷贝到v partial_sort_copy(arr, arr+9, v.begin(), v.end());partial_sort_copy(arr, arr+9, v.begin(), v.end(), f) bool f(int i,int j) { return (i<j); }
*is_sorted 返回一个bool判断是否已排序 std::is_sorted(v.begin(),v.end())
*is_sorted_until 返回第一个未排序的迭代器,若不存在则返回尾迭代器 is_sorted_until(v.begin(),v.end())
nth_element 将第5大的元素放到第5的位置,比它小的在前,大的在后 nth_element(v.begin(), v.begin()+5, v.end());nth_element(v.begin(), v.begin()+5, v.end(), f) bool f(int i,int j) { return (i<j); }

Binary search

函数名 功能 形式 f
lower_bound 返回第一个大于等于20的元素的迭代器 lower_bound (v.begin(), v.end(), 20)
upper_bound 返回第一个大于20的元素的迭代器 upper_bound (v.begin(), v.end(), 20)
equal_range 返回一个part,part.first为lower_bound,part.second为upper_bound,如果f为>则相反 equal_range (v.begin(), v.end(), 20);equal_range (v.begin(), v.end(), 20, f) bool f(int i,int j) { return (i>j); }
binary_search 二分查找,返回一个bool binary_search (v.begin(), v.end(), 3);binary_search (v.begin(), v.end(), 3, f) bool f(int i,int j) { return (i<j); }

Merge

函数名 功能 形式 f
merge 将两个有序序列合并到v并排序 merge (first,first+5,second,second+5,v.begin())
inplace_merge 连接在一起的序列[first,middle)和[middle,last)都已排序,将其归并为单一有序序列 inplace_merge(v.begin(),v.begin()+5,v.end())
includes 返回一个bool,判断arr2是否为arr1的子集 includes(arr1,arr1+10,arr2,arr2+4);includes(arr1,arr1+10,arr2,arr2+4,f) bool f(int i,int j) { return (i<j); }
set_union 将两个集合的并集拷贝到v,返回并集元素数后一个迭代器 set_union(first, first+5, second, second+5, v.begin())
set_intersection 交集 同上
set_difference 范围1减去范围2的差集 同上
set_symmetric_difference 对称差 同上

Heap

函数名 功能 形式
push_heap 向堆中加一个元素 v.push_back(99);push_heap(v.begin(),v.end())
pop_heap 删除堆中最大元素 pop_heap(v.begin(),v.end())
make_heap 用指定范围造一个堆 make_heap(v.begin(),v.end())
sort_heap 堆排序 sort_heap(v.begin(),v.end())
*is_heap 判断是否为二叉堆结构,返回一个bool is_heap(v.begin(),v.end())
*is_heap_until 返回第一个破坏二叉堆结构的迭代器 is_heap_until(v.begin(),v.end())

Min/max

函数名 功能 形式 f
min 返回较小元素 min('a','z')
max 返回较大元素 max(3.3, 2.5)
*minmax 返回一个pair,pair.first为最小值,pair.second为最大值 auto result = minmax({1,2,3,4,5})
min_element 返回范围内最小值的迭代器 min_element(myints,myints+7);min_element(myints,myints+7,f) bool myfn(int i, int j) { return i<j; };struct myclass { bool operator() (int i,int j) { return i<j; }} f;
max_element 返回范围内最大值的迭代器 同上
*minmax_element 返回一个pair,pair.first为最小值的迭代器,pair.second为最大值的迭代器 auto result = std::minmax_element(v.begin(),v.end())

Other

函数名 功能 形式
lexicographical_compare 按字典序比较两个序列 lexicographical_compare(foo,foo+5,bar,bar+9, compare)
next_permutation 范围按字典序的下一个排列组合,若没有则返回false next_permutation(arr,arr+3)
prev_permutation 范围按字典序的上一个排列组合,若没有则返回false prev_permutation(arr,arr+3)
上一篇 下一篇

猜你喜欢

热点阅读