青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

面對現實,超越自己
逆水行舟,不進則退
posts - 269,comments - 32,trackbacks - 0
解釋
      迭代器是一種對象,它能夠用來遍歷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;
posted on 2012-06-05 13:59 王海光 閱讀(1093) 評論(0)  編輯 收藏 引用 所屬分類: STL
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            国产精品福利在线| 亚洲一区二区三区国产| 亚洲精品视频一区| 亚洲美女淫视频| 在线亚洲精品| 亚洲一区在线视频| 欧美一区二区三区免费大片| 久久精品中文字幕一区二区三区 | 国产日韩在线看| 国产一区二区三区日韩| 在线日韩中文字幕| 日韩系列欧美系列| 午夜精品久久久久久久99水蜜桃 | 亚洲国产欧美不卡在线观看| 伊人久久男人天堂| 亚洲精品在线观看免费| 99精品欧美一区二区三区 | 欧美成人免费观看| aⅴ色国产欧美| 欧美中文在线视频| 欧美激情精品久久久久久久变态| 欧美激情欧美激情在线五月| 国产精品毛片va一区二区三区| 韩国免费一区| 亚洲午夜精品一区二区三区他趣| 欧美中文在线观看| 亚洲区一区二| 久久精品成人一区二区三区| 欧美久久一级| 激情综合电影网| 亚洲欧美日韩综合国产aⅴ| 欧美成人综合在线| 亚洲欧美一区二区原创| 欧美精品久久久久久久| 国内精品视频在线观看| 亚洲视频网站在线观看| 欧美韩日高清| 久久久蜜桃精品| 国产免费观看久久黄| 夜夜爽夜夜爽精品视频| 麻豆av福利av久久av| 亚洲网址在线| 欧美久久综合| 亚洲美女视频网| 欧美风情在线观看| 久久久久国产精品午夜一区| 国产精品视频yy9099| 99国产麻豆精品| 亚洲高清影视| 免费精品99久久国产综合精品| 国产在线不卡精品| 久久超碰97人人做人人爱| 一区二区欧美日韩| 欧美色精品在线视频| 99综合在线| 亚洲精品在线观| 欧美日韩第一区日日骚| 亚洲精品日韩激情在线电影| 免费试看一区| 久久一区二区三区国产精品| 狠狠色丁香婷婷综合影院| 欧美亚洲一区三区| 午夜在线电影亚洲一区| 国产伦精品一区二区三区高清| 亚洲一级一区| 亚洲图片欧洲图片日韩av| 国产精品久久久久久久久免费| 亚洲图片欧美一区| 亚洲综合第一页| 国产日韩亚洲欧美综合| 亚洲国产精品精华液网站| 久久国产婷婷国产香蕉| 国产精品麻豆va在线播放| 欧美日韩视频不卡| 黄色日韩网站视频| 美女久久一区| 亚洲日韩欧美视频一区| 欧美精品国产精品日韩精品| 在线不卡免费欧美| 欧美成人精品三级在线观看| 久久综合一区二区| 亚洲乱码国产乱码精品精| 亚洲三级视频在线观看| 欧美午夜精品理论片a级大开眼界| 亚洲美女精品一区| 亚洲图片欧美日产| 狠狠入ady亚洲精品经典电影| 欧美成人免费观看| 欧美日韩视频在线| 久久久精品一区| 欧美成人综合一区| 午夜久久美女| 老**午夜毛片一区二区三区| 一区二区不卡在线视频 午夜欧美不卡在 | 欧美久久一区| 中日韩高清电影网| 欧美一区=区| 91久久精品国产91久久| 亚洲精品一区二区在线观看| 国产麻豆91精品| 久久亚洲精品伦理| 欧美韩国一区| 欧美在线一级va免费观看| 久久免费视频一区| 亚洲美女在线看| 性刺激综合网| 一区二区三区高清不卡| 亚洲综合国产激情另类一区| 在线观看国产一区二区| 一本大道av伊人久久综合| 狠狠色综合色综合网络| 一区二区三区视频在线看| 亚洲韩国一区二区三区| 欧美一区二区国产| 亚洲一区二区视频在线| 亚洲欧美日韩国产一区| 欧美二区在线播放| 久久aⅴ乱码一区二区三区| 欧美a级片一区| 久久精品视频一| 欧美日韩裸体免费视频| 另类激情亚洲| 国产日韩亚洲欧美精品| 在线亚洲成人| 一本久道综合久久精品| 男男成人高潮片免费网站| 久久久久88色偷偷免费| 国产精品久久国产三级国电话系列| 欧美电影免费观看| 国产中文一区| 欧美伊久线香蕉线新在线| 亚洲欧美在线一区二区| 欧美视频一区二| 99xxxx成人网| 亚洲一区二区精品在线| 欧美三级视频在线播放| 日韩特黄影片| 亚洲综合电影| 国产精品区一区二区三| 亚洲午夜国产成人av电影男同| 亚洲亚洲精品在线观看 | 久久久久国产精品午夜一区| 性做久久久久久久免费看| 国产精品盗摄久久久| 一本色道久久88精品综合| 亚洲午夜激情在线| 国产精品蜜臀在线观看| 亚洲欧美精品在线| 久久精品国产成人| 国内精品视频在线播放| 久久久精品一区| 欧美高清视频免费观看| 亚洲精选视频免费看| 欧美日韩在线三区| 亚洲综合不卡| 另类图片国产| 日韩天堂在线观看| 国产精品福利在线观看| 亚洲欧美日韩一区二区三区在线| 久久激情五月丁香伊人| 亚洲高清不卡一区| 欧美日韩亚洲视频一区| 小黄鸭精品aⅴ导航网站入口 | 蜜桃av一区二区在线观看| 亚洲福利在线观看| 欧美视频免费| 久久国产精品久久久| 亚洲承认在线| 午夜宅男欧美| 亚洲人成精品久久久久| 国产精品分类| 麻豆精品在线观看| 一区二区日韩精品| 久久躁日日躁aaaaxxxx| 亚洲狼人精品一区二区三区| 国产精品日韩久久久| 久久伊人一区二区| 亚洲网站在线看| 欧美激情一区| 欧美一区二区高清| 亚洲精品乱码久久久久久日本蜜臀 | 久久久精品日韩| 亚洲久久一区| 久久综合狠狠综合久久综合88| 亚洲精华国产欧美| 国产麻豆一精品一av一免费| 噜噜噜噜噜久久久久久91| 亚洲性图久久| 亚洲欧洲日产国产网站| 久久成人精品一区二区三区| 亚洲精品久久久久久久久久久久| 国产精品视频第一区| 欧美激情综合在线| 久久久亚洲高清| 亚洲欧美激情在线视频| 日韩视频免费在线| 欧美二区不卡| 麻豆久久婷婷| 久久蜜桃资源一区二区老牛| 亚洲欧美日韩在线不卡|