亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > C++ > 正文

c++11新增的便利算法實例分析

2020-05-23 14:21:49
字體:
來源:轉載
供稿:網友
這篇文章主要介紹了c++11新增的便利算法,主要有用于判斷、查找、數組、序列等的操作算法,非常具有實用價值,需要的朋友可以參考下
 
 

C++是一門應用非常廣泛的程序設計語言,而c++11則新增加了一些便利的算法,這些新增的算法使我們的代碼寫起來更簡潔方便,本文列舉一些常用的新增算法,算是做個總結分析,更多的新增算法讀者可以參考:http://en.cppreference.com/w/cpp/algorithm。

算法庫新增了三個用于判斷的算法all_of、any_of和none_of,定義如下:

template< class InputIt, class UnaryPredicate >bool all_of( InputIt first, InputIt last, UnaryPredicate p );template< class InputIt, class UnaryPredicate >bool any_of( InputIt first, InputIt last, UnaryPredicate p );template< class InputIt, class UnaryPredicate >bool none_of( InputIt first, InputIt last, UnaryPredicate p );

① all_of:檢查區間[first, last)中是否所有的元素都滿足一元判斷式p,所有的元素都滿足條件返回true,否則返回false。
② any_of:檢查區間[first, last)中是否至少有一個元素都滿足一元判斷式p,只要有一個元素滿足條件就返回true,否則返回true。
③ none_of:檢查區間[first, last)中是否所有的元素都不滿足一元判斷式p,所有的元素都不滿足條件返回true,否則返回false。

下面是這幾個算法的示例:

#include <iostream>#include <algorithm>#include <vector>using namespace std;int main(){    vector<int> v = { 1, 3, 5, 7, 9 };   auto isEven = [](int i){return i % 2 != 0;    bool isallOdd = std::all_of(v.begin(), v.end(), isEven);    if (isallOdd)       cout << "all is odd" << endl;    bool isNoneEven = std::none_of(v.begin(), v.end(), isEven);    if (isNoneEven)       cout << "none is even" << endl;    vector<int> v1 = { 1, 3, 5, 7, 8, 9 };    bool anyof = std::any_of(v1.begin(), v1.end(), isEven);    if (anyof)       cout << "at least one is even" << endl;}

輸出:

all is odd
none is odd
at least one is even

算法庫的查找算法新增了一個find_if_not,它的含義和find_if是相反的,即查找不符合某個條件的元素,find_if也可以實現find_if_not的功能,只需要將判斷式改為否定的判斷式即可,現在新增了find_if_not之后,就不需要再寫否定的判斷式了,可讀性也變得更好。下面是它的基本用法:

#include <iostream>#include <algorithm>#include <vector>using namespace std;int main(){  vector<int> v = { 1, 3, 5, 7, 9,4 };  auto isEven = [](int i){return i % 2 == 0;};  auto firstEven = std::find_if(v.begin(), v.end(), isEven);  if (firstEven!=v.end())       cout << "the first even is " <<* firstEven << endl;    //用find_if來查找奇數則需要重新寫一個否定含義的判斷式  auto isNotEven = [](int i){return i % 2 != 0;};  auto firstOdd = std::find_if(v.begin(), v.end(),isNotEven);    if (firstOdd!=v.end())       cout << "the first odd is " <<* firstOdd << endl;    //用find_if_not來查找奇數則無需新定義判斷式    auto odd = std::find_if_not(v.begin(), v.end(), isEven);    if (odd!=v.end())       cout << "the first odd is " <<* odd << endl;}

將輸出:

the first even is 4
the first odd is 1
the first odd is 1

可以看到使用find_if_not不需要再定義新的否定含義的判斷式了,更簡便了。

算法庫還增加了一個copy_if算法,它相比原來的copy算法多了一個判斷式,用起來更方便了,下面是它的基本用法:

#include <iostream>#include <algorithm>#include <vector>using namespace std;int main(){    vector<int> v = { 1, 3, 5, 7, 9, 4 };    std::vector<int> v1(v.size());    //根據條件拷貝    auto it = std::copy_if(v.begin(), v.end(), v1.begin(), [](int i){return i%2!=0;});    //縮減vector到合適大小    v1.resize(std::distance(v1.begin(),it));    for(int i : v1)    {       cout<<i<<" ";    }    cout<<endl;}  

算法庫新增了iota用來方便的生成有序序列,比如我們需要一個定長數組,這個數組中的元素都是在某一個數值的基礎之上遞增的,那么用iota可以很方便的生成這個數組了。下面是它的基本用法:

#include <numeric>#include <array>#include <vector>#include <iostream>using namespace std; int main(){vector<int> v(4) ;//循環遍歷賦值來初始化數組//for(int i=1; i<=4; i++)//{//  v.push_back(i);//}//直接通過iota初始化數組,更簡潔  std::iota(v.begin(), v.end(), 1);  for(auto n: v) {    cout << n << ' ';  }  cout << endl;    std::array<int, 4> array;  std::iota(array.begin(), array.end(), 1);  for(auto n: array) {    cout << n << ' ';  }  std::cout << endl;}

將輸出:

1 2 3 4
1 2 3 4

可以看到使用iota比遍歷賦值來初始化數組更簡潔,需要注意的是iota初始化的序列需要指定大小,如果上面的代碼中:vector<int> v(4) ;沒有指定初始化大小為4的話,則輸出為空。

算法庫還新增了一個同時獲取最大值和最小值的算法minmax_element,這樣我們如果想獲取最大值和最小值的時候就不用分別調用max_element和max_element算法了,用起來會更方便,minmax_element會將最小值和最大值的迭代器放到一個pair中返回,下面是它的基本用法:

#include <iostream>#include <algorithm>#include <vector>using namespace std;int main() {  // your code goes here  vector<int> v = { 1, 2, 5, 7, 9, 4 };  auto result = minmax_element(v.begin(), v.end());    cout<<*result.first<<" "<<*result.second<<endl;  return 0;}

將輸出:

1 9

算法庫新增了is_ sorted和is_ sorted_until算法,is_sort用來判斷某個序列是否是排好序的,is_sort_until則用來返回序列中前面已經排好序的部分序列。下面是它們的基本用法:

#include <iostream>#include <algorithm>#include <vector>using namespace std;int main() {  vector<int> v = { 1, 2, 5, 7, 9, 4 };  auto pos = is_sorted_until(v.begin(), v.end());    for(auto it=v.begin(); it!=pos; ++it)  {    cout<<*it<< " ";  }  cout<<endl;    bool is_sort = is_sorted(v.begin(), v.end());  cout<< is_sort<<endl;  return 0;}

將輸出:

1 2 5 7 9
0

總結:這些新增的算法讓我們用起來更加簡便,也增強了代碼的可讀性。

希望本文所述算法對大家更好的掌握C++11能有所幫助。


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
国产99久久久欧美黑人| 中文字幕日韩欧美| 日韩精品视频免费专区在线播放| 成人黄色av播放免费| 久久99国产精品自在自在app| 国产精自产拍久久久久久| 亚洲最新视频在线| 日韩电影在线观看免费| 亚洲一级黄色av| 精品久久香蕉国产线看观看亚洲| 亚洲女人天堂视频| 亚洲人成伊人成综合网久久久| 亚洲自拍偷拍色片视频| 国产日本欧美视频| 成人黄色免费在线观看| 国产成人精品日本亚洲| 国产精品久久久久久久久久小说| 国产精品伦子伦免费视频| 国产精品久久久久久久久免费| 91欧美激情另类亚洲| 亚洲乱码一区二区| 中文字幕国内精品| 国产在线视频欧美| 91亚洲国产成人精品性色| 亚洲欧美成人网| 亚洲毛片在线观看| 亚洲天堂成人在线视频| 日韩中文字幕网站| 亚洲电影成人av99爱色| 日韩成人中文字幕在线观看| 亚洲а∨天堂久久精品喷水| 日韩精品中文字幕在线观看| 美女久久久久久久久久久| 午夜精品久久久久久久99黑人| 久久久最新网址| 欧美成人精品不卡视频在线观看| 国产丝袜一区二区三区| 日本中文字幕成人| 国产精品久久久久久久久久久久久| 97在线免费观看视频| 久久av在线播放| 91精品国产综合久久男男| 91成人在线播放| 欧美激情视频给我| 日本免费在线精品| 久久久久久久久久久91| 欧美精品日韩www.p站| 亚洲精品理论电影| 国产成人精品999| 亚洲午夜小视频| 欧美一乱一性一交一视频| 欧美激情亚洲一区| 日本国产精品视频| 高清一区二区三区四区五区| 国产精品99久久久久久白浆小说| 亚洲人成人99网站| 久久久久久久999精品视频| 狠狠色狠色综合曰曰| 成人美女免费网站视频| 91精品久久久久久久久久入口| 欧美xxxx做受欧美.88| 亚洲91精品在线观看| 久久免费视频在线观看| 日韩成人在线观看| 亚洲精品国产suv| 国产精品免费网站| 欧美在线一区二区视频| 久久久久久久久久久av| 成人在线视频福利| 亚洲女人天堂视频| 国产精品视频网| 日韩欧美亚洲成人| www.日韩系列| 亚洲一级片在线看| 97精品免费视频| 欧美激情按摩在线| 久久91精品国产91久久跳| 国产精品jvid在线观看蜜臀| 久久精视频免费在线久久完整在线看| 欧美xxxx做受欧美.88| 日韩经典一区二区三区| 欧美在线亚洲在线| 欧美亚洲视频在线观看| 亚洲欧美成人一区二区在线电影| 久久91亚洲精品中文字幕奶水| 亚洲春色另类小说| 欧美中文字幕视频| 国模精品一区二区三区色天香| 国产精品久久婷婷六月丁香| 亚洲第一福利视频| 日韩欧美aⅴ综合网站发布| 91国产美女在线观看| 国产精品高清免费在线观看| 日韩精品在线第一页| 欧美夫妻性视频| 久久视频在线播放| 色偷偷91综合久久噜噜| 在线日韩欧美视频| 国产精品久久久久久久app| 成人av色在线观看| 欧美极品欧美精品欧美视频| 国产一区二区三区欧美| 韩国福利视频一区| 日韩精品中文字幕视频在线| 色悠久久久久综合先锋影音下载| 98视频在线噜噜噜国产| 精品久久久久久久久中文字幕| 在线亚洲国产精品网| 久久久久久久久久av| 欧美日韩国产丝袜美女| 黄色91在线观看| 在线电影中文日韩| 久久精品国产亚洲一区二区| www高清在线视频日韩欧美| 亚洲精品国产福利| 亚洲性生活视频在线观看| 亚洲国产精品系列| 久久久视频免费观看| 欧美激情视频网址| 在线精品高清中文字幕| 成人欧美在线观看| 裸体女人亚洲精品一区| 日韩精品久久久久久久玫瑰园| 成人中心免费视频| 国产精品免费久久久| 欧美性猛交xxxx乱大交| 久久久久久久久久国产精品| 亚洲美女福利视频网站| 韩国三级日本三级少妇99| 成人亚洲欧美一区二区三区| 欧美激情网友自拍| 国产精品视频免费在线| 欧美激情视频在线观看| 亚洲精品电影在线| 97超碰蝌蚪网人人做人人爽| 国产精品福利在线观看网址| 国产综合香蕉五月婷在线| 国产91在线播放精品91| 在线观看日韩视频| 国产精品久久久久久av下载红粉| 亚洲精品电影久久久| 欧美日韩国产一区中文午夜| 国产成人鲁鲁免费视频a| 日韩av电影免费观看高清| www欧美xxxx| 国产成人啪精品视频免费网| 精品亚洲aⅴ在线观看| 精品高清一区二区三区| 国产午夜精品全部视频在线播放| 欧美成人精品在线| 久久精品成人欧美大片| 欧美激情精品久久久久久大尺度| 国产成人精品国内自产拍免费看| 最新国产成人av网站网址麻豆| 国产精品久久久久久久久粉嫩av| 中文字幕日韩精品有码视频| 久久精品国亚洲| 精品中文字幕久久久久久| 久久久久亚洲精品成人网小说| 国产一区二区三区网站| 91国内产香蕉| 在线中文字幕日韩| 久久精品国产一区| 亚洲国产精品99久久|