STL迭代器

STL迭代器及总结
解释
      迭代器是一种对象,它能够用来遍历STL容器中的部分或全部元素,每个迭代器对象代表容器中的确定的地址。迭代器修改了常规指针的接口,所谓迭代器是一种概念上的抽象:那些行为上象迭代器的东西都可以叫做迭代器。然而迭代器有很多不同的能力,它可以把抽象容器和通用算法有机的统一起来。
      迭代器提供一些基本操作符:*、++、==、!=、=。这些操作和C/C++“操作array元素”时的指针接口一致。不同之处在于,迭代器是个所谓的smart pointers,具有遍历复杂数据结构的能力。其下层运行机制取决于其所遍历的数据结构。因此,每一种容器型别都必须提供自己的迭代器。事实上每一种容器都将其迭代器以嵌套的方式定义于内部。因此各种迭代器的接口相同,型别却不同。这直接导出了泛型程序设计的概念:所有操作行为都使用相同接口,虽然它们的型别不同。

功能特点
      迭代器使开发人员不必整个实现类接口。只需提供一个迭代器,即可遍历类中的数据结构,可被用来访问一个容器类的所包函的全部元素,其行为像一个指针,但是只可被进行增加(++)或减少(--)操作。举一个例子,你可用一个迭代器来实现对vector容器中所含元素的遍历。
      如下代码对vector容器对象生成和使用了迭代器:
 1 vector<int> the_vector;
 2 vector<int>::iterator the_iterator;
 3     forint i=0; i < 10; i++ )
 4 the_vector.push_back(i);
 5 int total = 0;
 6 the_iterator = the_vector.begin();
 7 while( the_iterator != the_vector.end() ) 
 8 {
 9     total += *the_iterator;
10     the_iterator++;
11 }
12 cout << "Total=" << total << endl;
提示:通过对一个迭代器的解引用操作(*),可以访问到容器所包含的元素。

C++标准库总结

容器
序列
      vector=========================<vector>
      list===========================<list>
      deque==========================<deque>

序列适配器
      stack:top,push,pop=============<stack>
      queue:front,back,push,pop======<queue>
      priority_queue:top,push,pop====<queue>

关联容器
      map============================<map>
      multimap=======================<map>
      set============================<set>
      multiset=======================<set>

拟容器
      string=========================<string>
      valarray=======================<valarray>
      bitset=========================<bitset>

算法
http://www.cplusplus.com/reference/algorithm/       STL Algorithms 详细说明

非修改性序列操作
<algorithm>
      for_each()=====================对序列中每个元素执行操作
      find()=========================在序列中找某个值的第一个出现
      find_if()======================在序列中找符合某谓词的第一个元素
      find_first_of()================在序列中找另一序列里的值
      adjust_find()==================找出相邻的一对值
      count()========================在序列中统计某个值出现的次数
      count_if()=====================在序列中统计与某谓词匹配的次数
      mismatch()=====================找使两序列相异的第一个元素
      equal()========================如果两个序列对应元素都相同则为真
      search()=======================找出一序列作为子序列的第一个出现位置
      find_end()=====================找出一序列作为子序列的最后一个出现位置
      search_n()=====================找出一序列作为子序列的第n个出现位置
修改性的序列操作
<algorithm>
      transform()====================将操作应用于序列中的每个元素
      copy()=========================从序列的第一个元素起进行复制
      copy_backward()================从序列的最后元素起进行复制
      swap()=========================交换两个元素
      iter_swap()====================交换由迭代器所指的两个元素
      swap_ranges()==================交换两个序列中的元素
      replace()======================用一个给定值替换一些元素
      replace_if()===================替换满足谓词的一些元素
      replace_copy()=================复制序列时用一个给定值替换元素
      replace_copy_if()==============复制序列时替换满足谓词的元素
      fill()=========================用一个给定值取代所有元素
      fill_n()=======================用一个给定值取代前n个元素
      generate()=====================用一个操作的结果取代所有元素
      generate_n()===================用一个操作的结果取代前n个元素
      remove()=======================删除具有给定值的元素
      remove_if()====================删除满足谓词的元素
      remove_copy()==================复制序列时删除给定值的元素
      remove_copy_if()===============复制序列时删除满足谓词的元素
      unique()=======================删除相邻的重复元素
      unique_copy()==================复制序列时删除相邻的重复元素
      reexample()======================反转元素的次序
      reexample_copy()=================复制序列时反转元素的次序
      rotate()=======================循环移动元素
      rotate_copy()==================复制序列时循环移动元素
      random_shuffle()===============采用均匀分布随机移动元素
序列排序
<algorithm>
      sort()=========================以很好的平均次序排序
      stable_sort()==================排序且维持相同元素原有的顺序
      partial_sort()=================将序列的前一部分排好序
      partial_sort_copy()============复制的同时将序列的前一部分排好序
      nth_element()==================将第n个元素放到它的正确位置
      lower_bound()==================找到某个值的第一个出现
      upper_bound()==================找到大于某个值的第一个出现
      equal_range()==================找出具有给定值的一个子序列
      binary_search()================在排好序的序列中确定给定元素是否存在
      merge()========================归并两个排好序的序列
      inplace_merge()================归并两个接续的排好序的序列
      partition()====================将满足某谓词的元素都放到前面
      stable_partition()=============将满足某谓词的元素都放到前面且维持原顺序
集合算法
<algorithm>
      include()======================如果一个序列是另一个的子序列则为真
      set_union()====================构造一个已排序的并集
      set_intersection()=============构造一个已排序的交集
      set_difference()===============构造一个已排序序列,包含在第一个序列但不在第二个序列的元素
      set_symmetric_difference()=====构造一个已排序序列,包括所有只在两个序列之一中的元素
堆操作
<algorithm>
      make_heap()====================将序列高速得能够作为堆使用
      push_heap()====================向堆中加入一个元素
      pop_heap()=====================从堆中去除元素
      sort_heap()====================对堆排序
最大和最小
<algorithm>
      min()==========================两个值中较小的
      max()==========================两个值中较大的
      min_element()==================序列中的最小元素
      max_element()==================序列中的最大元素
      lexicographic_compare()========两个序列中按字典序的第一个在前
排列
<algorithm>
      next_permutation()=============按字典序的下一个排列
      prev_permutation()=============按字典序的前一个排列
通用数值算法
<numeric>
      accumulate()===================积累在一个序列中运算的结果(向量的元素求各的推广)
      inner_product()================积累在两个序列中运算的结果(内积)
      partial_sum()==================通过在序列上的运算产生序列(增量变化)
      adjacent_difference()==========通过在序列上的运算产生序列(与partial_sum相反)
C风格算法
<cstdlib>
      qsort()========================快速排序,元素不能有用户定义的构造,拷贝赋值和析构函数
      bsearch()======================二分法查找,元素不能有用户定义的构造,拷贝赋值和析构函数

函数对象
基类

      template<class Arg, class Res> struct unary_function
      template<class Arg, class Arg2, class Res> struct binary_function
谓词
返回bool的函数对象。
<functional>
      equal_to=======================二元,arg1 == arg2
      not_equal_to===================二元,arg1 != arg2
      greater========================二元,arg1 > arg2
      less===========================二元,arg1 < arg2
      greater_equal==================二元,arg1 >= arg2
      less_equal=====================二元,arg1 <= arg2
      logical_and====================二元,arg1 && arg2
      logical_or=====================二元,arg1 || arg2
      logical_not====================一元,!arg
算术函数对象
<functional>
      plus===========================二元,arg1 + arg2
      minus==========================二元,arg1 - arg2
      multiplies=====================二元,arg1 * arg2
      divides========================二元,arg1 / arg2
      modulus========================二元,arg1 % arg2
      negate=========================一元,-arg
约束器,适配器和否定器
<functional>
      bind2nd(y)
            binder2nd==================以y作为第二个参数调用二元函数
      bind1st(x)
            binder1st==================以x作为第一个参数调用二元函数
      mem_fun()
            mem_fun_t==================通过指针调用0元成员函数
            mem_fun1_t=================通过指针调用一元成员函数
            const_mem_fun_t============通过指针调用0元const成员函数
            const_mem_fun1_t===========通过指针调用一元const成员函数
      mem_fun_ref()
            mem_fun_ref_t==============通过引用调用0元成员函数
            mem_fun1_ref_t=============通过引用调用一元成员函数
            const_mem_fun_ref_t========通过引用调用0元const成员函数
            const_mem_fun1_ref_t=======通过引用调用一元const成员函数
      ptr_fun()
            pointer_to_unary_function==调用一元函数指针
      ptr_fun()
            pointer_to_binary_function=调用二元函数指针
      not1()
            unary_negate===============否定一元谓词
      not2()
            binary_negate==============否定二元谓词

迭代器
分类
      
      Output: *p= , ++
      Input: =*p , -> , ++ , == , !=
      Forward: *p= , =*p , -> , ++ , == , !=
      Bidirectional: *p= , =*p -> , [] , ++ , -- , == , !=
      Random: += , -= , *p= , =*p -> , [] , ++ , -- , + , - , == , != , < , > , <= , >=
插入器
      template<class Cont> back_insert_iterator<Cont> back_inserter(Cont& c);
      template<class Cont> front_insert_iterator<Cont> front_inserter(Cont& c);
      template<class Cont, class Out> insert_iterator<Cont> back_inserter(Cont& c, Out p);
反向迭代器
      reexample_iterator===============rbegin(), rend()
流迭代器
      ostream_iterator===============用于向ostream写入
      istream_iterator===============用于向istream读出
      ostreambuf_iterator============用于向流缓冲区写入
      istreambuf_iterator============用于向流缓冲区读出

分配器
<memory>
      template<class T> class std::allocator

数值
数值的限制
<limits>
      numeric_limits<>
<climits>
      CHAR_BIT
      INT_MAX
      ...
<cfloat>
      DBL_MIN_EXP
      FLT_RADIX
      LDBL_MAX
      ...
标准数学函数
<cmath>
      double abs(double)=============绝对值(不在C中),同fabs()
      double fabs(double)============绝对值
      double ceil(double d)==========不小于d的最小整数
      double floor(double d)=========不大于d的最大整数
      double sqrt(double d)==========d在平方根,d必须非负
      double pow(double d, double e)=d的e次幂
      double pow(double d, int i)====d的i次幂
      double cos(double)=============余弦
      double sin(double)=============正弦
      double tan(double)=============正切
      double acos(double)============反余弦
      double asin(double)============反正弦
      double atan(double)============反正切
      double atan2(double x,double y) //atan(x/y)
      double sinh(double)============双曲正弦
      double cosh(double)============双曲余弦
      double tanh(double)============双曲正切
      double exp(double)=============指数,以e为底
      double log(double d)===========自动对数(以e为底),d必须大于0
      double log10(double d)=========10底对数,d必须大于0
      double modf(double d,double*p)=返回d的小数部分,整数部分存入*p
      double frexp(double d, int* p)=找出[0.5,1)中的x,y,使d=x*pow(2,y),返回x并将y存入*p
      double fmod(double d,double m)=浮点数余数,符号与d相同
      double ldexp(double d, int i)==d*pow(2,i)
<cstdlib>
      int abs(int)===================绝对值
      long abs(long)=================绝对值(不在C中)
      long labs(long)================绝对值
      struct div_t { implementation_defined quot, rem; }
      struct ldiv_t { implementation_defined quot, rem; }
      div_t div(int n, int d)========用d除n,返回(商,余数)
      ldiv_t div(long n, long d)=====用d除n,返回(商,余数)(不在C中)
      ldiv_t ldiv(long n, long d)====用d除n,返回(商,余数)
向量算术
<valarray>
      valarray
复数算术
<complex>
      template<class T> class std::complex;

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/509042.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

C++ Sets MultiSets

C Sets & MultiSetsSTL Set介绍 集合(Set)是一种包含已排序对象的关联容器。多元集合(MultiSets)和集合(Sets)相像&#xff0c;只不过支持重复对象,其用法与set基本相同。Set 又称集合&#xff0c;实际上就是一组元素的集合&#xff0c;但其中所包含的元素的值是唯一的&am…

SSDB 配置文件详解

SSDB 的配置非常简单, 附带的 ssdb.conf 你不用修改便可以使用. 如果你要高度定制, 还是需要修改一些配置的. 下面做介绍. SSDB 的配置文件是一种层级 key-value 的静态配置文件, 通过一个 TAB 缩进来表示层级关系. 以 # 号开始的行是注释. 标准的配置文件如下: # ssdb-serve…

C++ Maps MultiMaps

C Maps & MultiMapsC Maps & MultiMaps C Maps是一种关联式容器&#xff0c;包含“关键字/值”对。C Multimaps和maps很相似&#xff0c;但是MultiMaps允许重复的元素。1.begin() 返回指向map头部的迭代器2.clear() 删除所有元素3.count() 返回指定元素出现的次数语法…

英语单词词干化表

博客&#xff1a;https://blog.csdn.net/potato012345/article/details/78091939 下载地址&#xff1a;https://github.com/Zhangtd/MorTransformation

c++ List(双向链表)

c List(双向链表)List(双向链表)介绍: List是一个线性链表结构&#xff0c;它的数据由若干个节点构成&#xff0c;每一个节点都包括一个信息块&#xff08;即实际存储的数据&#xff09;、一个前驱指针和一个后驱指针。它无需分配指定的内存大小且可以任意伸缩&#x…

Arrays.deepToString的使用

今天看别人的代码引用了这个函数&#xff0c;发现原来遍历数组(非List&#xff0c;例如&#xff1a;int [][] 类型等)可以直接调用Arrays.deepToString(数组名)可以直接输出结果&#xff0c;以前还傻不啦叽的的转换成List数组或者是for循环遍历。 Integer[][] allMovieComment…

C++ Vector(向量容器)

Vector介绍C Vector&#xff08;向量容器&#xff09; 是一个线性顺序结构。相当于数组&#xff0c;但其大小可以不预先指定&#xff0c;并且自动扩展。它可以像数组一样被操作&#xff0c;由于它的特性我们完全可以将vector 看作动态数组。 在创建一个vector 后&#xff0c;它…

出现特殊分隔符无法分隔解决方案

今天处理文本数据时候遇到这种文本用空格和tab正则匹配没有作用&#xff0c;后来问了同事发现可以用“\\uf8f5”去匹配。 待处理文本&#xff1a; A abbr.安  A-10IInone.美空军主力近距离空中支援攻击机&#xff0c;无愧为“坦克杀手”。 A-12none.夭折的美海…

java英文单词单复数转换

package steam;import java.util.*; import java.util.regex.*; /*** * 单复数转换类* 2018年12月30日*/public class Inflector {private static final Pattern UNDERSCORE_PATTERN_1 Pattern.compile("([A-Z])([A-Z][a-z])");private static final Pattern UNDERS…

最全英语单词下载地址

这两天搜集英文单词做词干化处理&#xff0c;虽说standford-NLP可以处理&#xff0c;但是效率不高&#xff0c;自己动手找单词做映射表&#xff0c;找单词真的痛苦&#xff01;&#xff01;&#xff01;放出以下地址最为保存和分享 github&#xff1a; https://github.com/dw…

NLP英文缩写词性含义

1. CC Coordinating conjunction 连接词 2. CD Cardinal number 基数词 3. DT Determiner 限定词&#xff08;如this,that,these,those,such&#xff0c;不定限定词&#xff1a;no,some,any,each,every,enough,either,neither,all,both,half,sever…

redis通过expire设置存活期注意问题

今天老大检查之前所做的项目发现项目过期数据仍然残留并没有删除&#xff0c;本以为自己设置了存活期就不用管数据了会自动删除掉&#xff0c;啊&#xff0c;果然自己太马虎了&#xff0c;如果是传统的kv类型&#xff0c;通过expire(key&#xff0c;alive_time)没有错误&#x…

次幂函数取模算法

次幂函数取模算法 高次幂函数取模算法 在平常的工作学习中&#xff0c;我们经常需要用到求取一个数字或者幂运算的余数&#xff0c;尤其在密码学中最为常用的RSA算法就经常要用到这种运算&#xff0c;我们称之为高次幂函数的取模运算。 在本篇文章中&#xff0c;将会首先介绍运…

【转载保存】接口压力测试安装与使用

https://blog.csdn.net/qq_26525215/article/details/79182674

mysql日期格式转换

select * from news where DATE_FORMAT(news_time, %Y-%m-%d %k:%i:%s) < " "" curDate "

java单例模式双重检查

public class Singleton {private static volatile Singleton singleton;private Singleton() {}public static Singleton getInstance() {if (singleton null) {synchronized (Singleton.class) {if (singleton null) {singleton new Singleton();}}}return singleton;} }

mysql 常用操作

mysql 常用操作&#xff08;整理&#xff09; 标签&#xff1a; MYSQL常用操作 2013-07-22 16:37 10846人阅读 评论(0) 收藏 举报 本文章已收录于&#xff1a; 分类&#xff1a; MYSQL 版权声明&#xff1a;本文为博主原创文章&#xff0c;未经博主允许不得转载。 目录(?)[]…

协同过滤算法UserCF和ItemCF优缺点对比

UserCF&#xff1a; 性能&#xff1a;适用于用户较少的场合&#xff0c;如果用户很多&#xff0c;计算用户相似度矩阵代价很大。领域&#xff1a;时效性较强&#xff0c;用户个性化兴趣不太明显的领域。实时性&#xff1a;用户有新行为&#xff0c;不一定造成推荐结果的立即变…

deque

STL之deque容器详解Deque 容器 deque容器是C标准模版库(STL,Standard Template Library)中的部分内容。deque容器类与vector类似&#xff0c;支持随机访问和快速插入删除&#xff0c;它在容器中某一位置上的操作所花费的是线性时间。与vector不同的是&#xff0c;deque还支持从…

【转载保存】MySQL时间、字符串、时间戳互相转换

时间转字符串 select date_format(now(), ‘%Y-%m-%d %H:%i:%s’); 结果&#xff1a;2018-05-02 20:24:10 时间转时间戳 select unix_timestamp(now()); 结果&#xff1a;1525263383 字符串转时间 select str_to_date(‘2018-05-02’, ‘%Y-%m-%d %H’); 结果&#xff1a;20…