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

Benjamin

靜以修身,儉以養德,非澹薄無以明志,非寧靜無以致遠。
隨筆 - 398, 文章 - 0, 評論 - 196, 引用 - 0
數據加載中……

STL算法(Algorithms):排序

一、sort:對一定范圍內的所有元素排序

原型:

template <class RandomAccessIterator>

  void sort ( RandomAccessIterator first, RandomAccessIterator last );

template <class RandomAccessIterator, class Compare>

  void sort ( RandomAccessIterator first, RandomAccessIterator last, Compare comp );
例子代碼:

// sort algorithm example

#include <iostream>

#include <algorithm>

#include <vector>

using namespace std;

 

bool myfunction (int i,int j) { return (i<j); }

 

struct myclass {

  bool operator() (int i,int j) { return (i<j);}

} myobject;

 

int main () {

  int myints[] = {32,71,12,45,26,80,53,33};

  vector<int> myvector (myints, myints+8);               // 32 71 12 45 26 80 53 33

  vector<int>::iterator it;

 

  // using default comparison (operator <):

  sort (myvector.begin(), myvector.begin()+4);           //(12 32 45 71)26 80 53 33

 

  // using function as comp

  sort (myvector.begin()+4, myvector.end(), myfunction); // 12 32 45 71(26 33 53 80)

 

  // using object as comp

  sort (myvector.begin(), myvector.end(), myobject);     //(12 26 32 33 45 53 71 80)

 

  // print out content:

  cout << "myvector contains:";

  for (it=myvector.begin(); it!=myvector.end(); ++it)

    cout << " " << *it;

 

  cout << endl;

 

  return 0;

}

二、stable_sort:歸并排序

原型:

template <class RandomAccessIterator>

  void stable_sort ( RandomAccessIterator first, RandomAccessIterator last );

template <class RandomAccessIterator, class Compare>

  void stable_sort ( RandomAccessIterator first, RandomAccessIterator last,

                     Compare comp );
例子代碼:

// stable_sort example

#include <iostream>

#include <algorithm>

#include <vector>

using namespace std;

 

bool compare_as_ints (double i,double j)

{

  return (int(i)<int(j));

}

 

int main () {

  double mydoubles[] = {3.14, 1.41, 2.72, 4.67, 1.73, 1.32, 1.62, 2.58};

 

  vector<double> myvector;

  vector<double>::iterator it;

 

  myvector.assign(mydoubles,mydoubles+8);

 

  cout << "using default comparison:";

  stable_sort (myvector.begin(), myvector.end());

  for (it=myvector.begin(); it!=myvector.end(); ++it)

    cout << " " << *it;

 

  myvector.assign(mydoubles,mydoubles+8);

 

  cout << "\nusing 'compare_as_ints' :";

  stable_sort (myvector.begin(), myvector.end(), compare_as_ints);

  for (it=myvector.begin(); it!=myvector.end(); ++it)

    cout << " " << *it;

 

  cout << endl;

 

  return 0;

}

三、partial_sort_copy:對序列中的某個范圍的元素進行排序(部分排序)

原型:

template <class InputIterator, class RandomAccessIterator>

  RandomAccessIterator

    partial_sort_copy ( InputIterator first,InputIterator last,

                        RandomAccessIterator result_first,

                        RandomAccessIterator result_last );

template <class InputIterator, class RandomAccessIterator, class Compare>

  RandomAccessIterator

    partial_sort_copy ( InputIterator first,InputIterator last,

                        RandomAccessIterator result_first,

                        RandomAccessIterator result_last, Compare comp );
示例代碼:

// partial_sort example
#include <iostream>
#include <algorithm>
#include <vector>
using namespace std;

bool myfunction (int i,int j) { return (i<j); }

int main () {
  int myints[] = {9,8,7,6,5,4,3,2,1};
  vector<int> myvector (myints, myints+9);
  vector<int>::iterator it;

  // using default comparison (operator <):
  partial_sort (myvector.begin(), myvector.begin()+5, myvector.end());

  // using function as comp
  partial_sort (myvector.begin(), myvector.begin()+5, myvector.end(),myfunction);

  // print out content:
  cout << "myvector contains:";
  for (it=myvector.begin(); it!=myvector.end(); ++it)
    cout << " " << *it;

  cout << endl;

  return 0;
}

四、partial_sort_copy部分排序后拷貝
原型:

template <class InputIterator, class RandomAccessIterator>

  RandomAccessIterator

    partial_sort_copy ( InputIterator first,InputIterator last,

                        RandomAccessIterator result_first,

                        RandomAccessIterator result_last );

template <class InputIterator, class RandomAccessIterator, class Compare>

  RandomAccessIterator

    partial_sort_copy ( InputIterator first,InputIterator last,

                        RandomAccessIterator result_first,

                        RandomAccessIterator result_last, Compare comp );

示例:

// partial_sort_copy example
#include <iostream>
#include <algorithm>
#include <vector>
using namespace std;

bool myfunction (int i,int j) { return (i<j); }

int main () {
  int myints[] = {9,8,7,6,5,4,3,2,1};
  vector<int> myvector (5);
  vector<int>::iterator it;

  // using default comparison (operator <):
  partial_sort_copy (myints, myints+9, myvector.begin(), myvector.end());

  // using function as comp
  partial_sort_copy (myints, myints+9, myvector.begin(), myvector.end(), myfunction);

  // print out content:
  cout << "myvector contains:";
  for (it=myvector.begin(); it!=myvector.end(); ++it)
    cout << " " << *it;

  cout << endl;

  return 0;
}
五、nth_element:使第n個元素處在序列中的第n個位置,并在這個元素前都是比這個元素小的,
這個元素后面都是比這個這元素大,但是這前后兩個序列并不一定都是有序的
(排過序);
 原型:

template <class RandomAccessIterator>

  void nth_element ( RandomAccessIterator first, RandomAccessIterator nth,

                     RandomAccessIterator last );

 

template <class RandomAccessIterator, class Compare>

  void nth_element ( RandomAccessIterator first, RandomAccessIterator nth,

                     RandomAccessIterator last, Compare comp );

例子代碼:
// nth_element example
#include <iostream>
#include <algorithm>
#include <vector>
using namespace std;

bool myfunction (int i,int j) { return (i<j); }

int main () {
  vector<int> myvector;
  vector<int>::iterator it;

  // set some values:
  for (int i=1; i<10; i++) myvector.push_back(i);   // 1 2 3 4 5 6 7 8 9

  random_shuffle (myvector.begin(), myvector.end());

  // using default comparison (operator <):
  nth_element (myvector.begin(), myvector.begin()+5, myvector.end());

  // using function as comp
  nth_element (myvector.begin(), myvector.begin()+5, myvector.end(),myfunction);

  // print out content:
  cout << "myvector contains:";
  for (it=myvector.begin(); it!=myvector.end(); ++it)
    cout << " " << *it;

  cout << endl;

  return 0;
}




 

posted on 2012-01-07 16:32 Benjamin 閱讀(528) 評論(0)  編輯 收藏 引用 所屬分類: 泛型編程

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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亚洲一区二区| 在线日韩成人| 久久精品国语| 亚洲综合视频一区| 你懂的国产精品永久在线| 亚洲欧美一区二区三区久久 | 亚洲在线免费| 久久国产精品黑丝| 亚洲免费av电影| 久久精品亚洲热| 亚洲一线二线三线久久久| 欧美在线不卡| 亚洲欧美日韩综合一区| 欧美成人按摩| 快播亚洲色图| 国产欧美一区二区三区久久| 亚洲国产精品电影| 在线日韩中文| 久久久国产精品一区二区中文| 一区二区三区黄色| 欧美国产日韩一二三区| 欧美大片专区| 在线国产欧美| 久久精品观看| 久久国产精品黑丝| 国产精品嫩草久久久久| 永久555www成人免费| 亚洲精品一区二区在线| 亚洲图片在区色| 国产精品久久久久久久久久久久| 一区二区三区高清视频在线观看| 亚洲图片在区色| 国产美女精品视频| 久久精品导航| 亚洲国产老妈| 亚洲男人的天堂在线| 国产精品一区亚洲| 午夜一区不卡| 欧美激情一二区| 国产精品99久久久久久久久| 国产精品免费电影| 久久国产视频网站| 最新成人在线| 午夜欧美大尺度福利影院在线看| 国产精品中文字幕欧美| 久久久久久久综合日本| 亚洲日本va在线观看| 欧美影片第一页| 亚洲国产欧美一区二区三区久久 | 国产日韩欧美不卡在线| 久久国产精品99久久久久久老狼| 欧美国产综合视频| 亚洲欧美中日韩| 亚洲国产91| 国产精品视频区| 欧美超级免费视 在线| 亚洲视频在线观看免费| 美日韩在线观看| 一区二区三区日韩欧美| 黄色精品一区二区| 国产精品成人一区二区三区夜夜夜 | 先锋影音国产一区| 欧美激情1区2区3区| 亚洲欧美日韩国产成人| 亚洲黄网站黄| 国产亚洲精品自拍| 欧美日韩国产片| 美女精品视频一区| 亚洲欧美视频| 亚洲精品一区二区三区不| 久久综合久久综合九色| 午夜精品福利一区二区三区av | 亚洲一区亚洲| 亚洲欧洲日产国产网站| 久久福利毛片| 午夜精品999| 亚洲一区二区欧美日韩| 亚洲日本在线视频观看| 一区二区三区在线高清| 国产网站欧美日韩免费精品在线观看| 欧美激情二区三区| 另类综合日韩欧美亚洲| 欧美在线一级视频| 亚洲女女女同性video| 99国产麻豆精品| 91久久综合| 亚洲激情一区二区| 亚洲第一精品久久忘忧草社区| 久久婷婷国产综合国色天香| 性欧美长视频| 性欧美暴力猛交69hd| 亚洲免费伊人电影在线观看av| 亚洲美女色禁图| 亚洲国产一区在线| 亚洲激情成人网| 亚洲国产三级| 亚洲欧洲一区| 亚洲精品国产拍免费91在线| 亚洲国产精品精华液2区45| 在线观看精品| 亚洲韩日在线| 亚洲精品欧美日韩专区| 亚洲精品视频免费观看| 亚洲另类视频| 99国产精品久久久久久久久久 | 欧美日本一道本| 欧美人与禽猛交乱配视频| 欧美高清视频一区| 欧美精品在线免费播放| 欧美日韩高清在线| 国产精品久久久对白| 国产精品香蕉在线观看| 国产亚洲二区| 在线看片日韩| 亚洲欧洲三级电影| 在线中文字幕一区| 午夜精品网站| 久久亚裔精品欧美| 欧美成人免费一级人片100| 亚洲国产中文字幕在线观看| 日韩视频在线播放| 亚洲一区二区在线观看视频| 欧美一区二区三区免费大片| 欧美一区二区三区喷汁尤物| 欧美在线播放视频| 免费欧美日韩| 国产精品九九| 国产一区欧美日韩| 亚洲人妖在线| 亚洲欧美日韩精品久久久久| 久久免费视频一区| 亚洲乱码国产乱码精品精| 亚洲欧美国产77777| 久久久久国产一区二区| 欧美理论片在线观看| 国产欧美日韩亚洲精品| 亚洲人成网在线播放| 亚洲女人天堂av| 免费不卡在线观看| 亚洲午夜久久久久久尤物| 久久九九久久九九| 欧美色图一区二区三区| 一区二区三区在线视频观看| 亚洲视频在线观看网站| 久久视频国产精品免费视频在线| 亚洲激情二区| 欧美呦呦网站| 国产精品久久激情| 亚洲国产乱码最新视频| 亚洲欧美影音先锋| 亚洲激情女人| 久久狠狠亚洲综合| 国产精品美腿一区在线看| 亚洲经典三级| 久久婷婷国产综合精品青草| 99在线|亚洲一区二区| 久久网站免费| 国产综合av| 欧美一区二区三区四区在线观看| 亚洲国产天堂久久综合网| 欧美中文在线免费| 国产精品私拍pans大尺度在线 | 一区二区不卡在线视频 午夜欧美不卡在 | 久久人人97超碰精品888| 亚洲乱码国产乱码精品精| 久久一区二区三区四区| 国产欧美日韩激情| 亚洲香蕉视频| 亚洲九九精品| 欧美黄色日本| 亚洲黄色av| 麻豆精品网站| 久久精品国产99| 国产一区二区三区久久 | 在线一区二区三区四区| 欧美精品v日韩精品v国产精品| 激情成人在线视频| 久久精品视频导航| 亚洲欧美日韩成人高清在线一区| 欧美日韩久久| 在线亚洲美日韩| 亚洲日本中文字幕| 欧美激情麻豆| a4yy欧美一区二区三区| 最近中文字幕mv在线一区二区三区四区| 久久激情网站| 在线免费不卡视频| 欧美成人激情视频| 欧美成年人视频网站| 亚洲精品欧美极品| 亚洲品质自拍| 国产精品第一区| 先锋a资源在线看亚洲| 亚洲欧美三级在线| 国产一区二区在线观看免费播放|