首页 > 作文

C++序列操作函数学习最全指南

更新时间:2023-04-05 22:51:06 阅读: 评论:0

前言

标准库定义了许多用于操作序列的算法,大多在algorithm和numeric文件中,大多数函数的原理并不复杂,但是在很多情况下可以替代手写的情况,甚至更加优秀。

这类算法函数非常多,但是他们都有共同的结构,类似的参数特性,所以非常好记忆。比如我们最经典的std::sort(beg, end, cmp),其中beg和end为首尾地址,左闭右开,既可以是c指针,也可以是stl线性容器的迭代器。cmp是可选的函数,用于替代默认的群网名<比较规则。实际上大多数函数基本都是这种形式,记住一个就是记住一百个。

摘自c++ primer附录

a. 查找算法

简单查找

find查找序列中第一个等于val的值,返回其指针或迭代器,在没有找到时返回end。

find_if和find相同,不过查找标准变成使谓词(布尔函数)返回true的第一个值。如查找序列中第一个奇数:

find_if_not和find_if相反,不过返回的是第一个使值为假的函数。

count和count_if返回一个值,表示序列中多少值等于val或满足func1。

返回布尔值,all_of当序列全部满足时返回真,any_of在有一个满足时返回真,none_of在全部不满足时返回真。序列为空时,any_of返回假,另外两个返回真。

查找重复值

adjacent_find返回第一对相邻的重复元素(使用==比较或满足func为真的元素)的前面那个,若没有返回end
arch_n返回一个指针或迭代器,从此位置有count个相等元素(使用==比较),若没有返回end

查找子序列

arch返回第二个序列在第一个序列中出现的位置,find_end相反,返回最后出现的位置,没有时返回end1。find_first_of返回的是第二个序列中任一元素第一次出现在序列一的位置,此时序列二不是序列,而是充当集合。

b. 其他只读算法

对序列中每个数执行func1,很好用,很多时候可以减少代码量替代for。
mismatch比较两个序列中每一个元素,返回第一组不相等(使用==运算符)或使func2为假的位置(是一个pair),没有则返回俩end。
equal与mismatch类似,若所有元素相等(满足mismatch返回end),结果为true,否则fal。

c. 二分查找算法

老熟了。在序列lower_bound返回第一个大于等于val的位置,upper_bound返回第一个大于val的位置,equal_range相当于前两个加在一起,返回一个pair,即两个函数的结果组合江西经济管理职业学院,包含一个值与val全部相等的区间。

如std::vector<int> a = {1, 2, 3, 3, 3, 4, 5},lowerbound返回a.begin()+2,upperbound返回a.begin()+5,equal_range返回pair{a.begin()+2, a.begin()+5}。

binary_arch只回答序列里是否存在val,存在则返回true,不存在返回fal。

以上函数操作自定义结构时都只使用<号,可以使用可选的自定义cmp函数

d. 只写算法

fill和fill_n为区间所有元素赋值val,他们给出区间所用的参数不一样。generate不断执行gen函数,将返回值逐个赋值给区间。普通版本无返回值,_n版本返回尾指针。

copy和copy_n将范围元素全部拷贝到dest,copy_if拷贝符合条件的分数。在c++中,应该使尽量使用std::fill和std::copy替代memt和memcpy。

move移动整个序列,对序列每个值调用std::move(右值转化),移动到dest。

将序列元素调用func1后存入dest,第二个版本对两个序列调用func2后将结果存入dest。

merge将两个有序序列合并,输出到dest,cmp是可选的自定义比较函数。这个函数相等于归并排序的合并阶段。

inplace_merge将左右的有序序列在原序列中执行合并操作,cmp是可选的自定义比较函数。

iter_swap交换两个迭代器指向的元素,swap_ranges一一交换两个序列。

将序列中的oldval(或者满足func1)的元素替换为newval,copy版本将元素写进新序列

将序列元素从end开始倒序拷贝(或移动)到dest(dest仍是正序,也就是说它应该给定一个新序列尾位置)

将val赋值给beg,再把++val依次赋值给下一个元素,直到赋值完整个序列。

e. 划分和排序

划分

将序列划分成前后两段,满足func1的放在前面,不满足的放在后面,返回分界点位置。stable版本保证相同元素的顺序不发生改变。copy版本将满足func1的输入新序列beg2,不满足的输入beg3。

partition_point返回已经划分好的元素的分界点,is_partitioned返回序列是否划分好。

排序

将序列排序,默认使用<号,可以使用可选的cmp自定义函数。stable版本保证相等元素的顺序在操作后不改变

is_sorted返回bool值,表示是否已经排好序。is_sorted_until寻找从起点开始的最长有序序列,返回尾位置。

partial_sort部分排序,将前mid-beg小的元素填充到beg~mid中,copy版本将这些元素输出到新序列中。

nth_element是另一类部分排序,参数nth是一个位置,函数将围绕nth部分排序,nth之前的元素都小于它,nth之后的都大于他

f. 重排算法

remove和remove_if移除序列中指定元素或满足func1的函数。移除的方式是将之后的元素往前移动,因此是线性复杂度,不过之后的元素不会被消除。返回尾位置。copy版本将元素输出到新序列。

将已经排好序的序列中删除相邻元素,返回尾位置,用==运算符或func2判断相等,多余的元素被swap到尾位置之后。copy版本将元素输出到新序列。

将序列循环右移,将mid成为beg处首元素,mid之前的元素循环到end处。copy版本将元素输出到新序列。

翻转序列元素,不必多说。copy版本将元素输出到新序列。

随机中国行政区划打乱序列,可以带入自定义随机函数rand,或者外部传入随机数生成器func。

g. 排列

is_permutation求帮妹妹洗澡解两个序列是否互为排列。具体来说,若两个序列拥有相同元素且同一种元素个数都相等,就是真,否则是假。
prev_permutation和next_permutation返回序列的上一个或者下一个排列(字典序意义),如果已经是最后一个排列,则循环到第一个排列,反之亦然。

h. 集合算法

这些算法用的比较少,将有序序列视作集合,执行一些集合操作。

include判断第二个序列是否包含在第一个序列中。

t_union和t_interction求集合的并集和交集,t_difference求只在第一个集合,不在第二个集合中的函数。t_symmetric_difference求只出现在一边的元素。他们都将结果输出到dest,返回dest的尾位置。默认使用<,可以使用自定cmp函数。

i. 杂项

双元素版本就不放了,现在min和max可以以列表形式支持变长参数了,英文名字女生简单气质如min({1,2,3})的形式,而minmax返回一个pair,fisrt和cond分别代表最小和最大值。

对序列求最值,返回的不是值,是指向目标值的指针或迭代器。可以使用自定cmp函数

比较两个序列的字典序,一次调用每个元素的<或cmp函数比较,若都相等则较短的序列更小,若长度也一样返回fal。

accumulate即字面意义“求和”,对序列从左往右求和,init为初始值,决定了返回值类型,默认调用+,可以自定函数;inner_product即字面意义“求内积”,将两个序列元素相乘再相加,默认调用*和+,两个函数都可以自定义。

字面意思,第一个求前缀和,第二个求差分,将结果输出到dest。默认使用+或-,可以自定义

总结

到此这篇关于c++序列操作函数学习指南的文章就介绍到这了,更多相关c++序列操作函数内容请搜索www.887551.com以前的文章或继续浏览下面的相关文章希望大家以后多多支持www.887551.com!

本文发布于:2023-04-05 22:51:03,感谢您对本站的认可!

本文链接:https://www.wtabcd.cn/fanwen/zuowen/44d82d7300023a6cad2e17e85f9190e5.html

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。

本文word下载地址:C++序列操作函数学习最全指南.doc

本文 PDF 下载地址:C++序列操作函数学习最全指南.pdf

标签:序列   元素   函数   第一个
相关文章
留言与评论(共有 0 条评论)
   
验证码:
Copyright ©2019-2022 Comsenz Inc.Powered by © 专利检索| 网站地图