c++11新增的便利算法實(shí)例分析
C++是一門(mén)應(yīng)用非常廣泛的程序設(shè)計(jì)語(yǔ)言,而c++11則新增加了一些便利的算法,這些新增的算法使我們的代碼寫(xiě)起來(lái)更簡(jiǎn)潔方便,本文列舉一些常用的新增算法,算是做個(gè)總結(jié)分析,更多的新增算法讀者可以參考:http://en.cppreference.com/w/cpp/algorithm。
算法庫(kù)新增了三個(gè)用于判斷的算法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:檢查區(qū)間[first, last)中是否所有的元素都滿足一元判斷式p,所有的元素都滿足條件返回true,否則返回false。
② any_of:檢查區(qū)間[first, last)中是否至少有一個(gè)元素都滿足一元判斷式p,只要有一個(gè)元素滿足條件就返回true,否則返回true。
③ none_of:檢查區(qū)間[first, last)中是否所有的元素都不滿足一元判斷式p,所有的元素都不滿足條件返回true,否則返回false。
下面是這幾個(gè)算法的示例:
#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
算法庫(kù)的查找算法新增了一個(gè)find_if_not,它的含義和find_if是相反的,即查找不符合某個(gè)條件的元素,find_if也可以實(shí)現(xiàn)find_if_not的功能,只需要將判斷式改為否定的判斷式即可,現(xiàn)在新增了find_if_not之后,就不需要再寫(xiě)否定的判斷式了,可讀性也變得更好。下面是它的基本用法:
#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來(lái)查找奇數(shù)則需要重新寫(xiě)一個(gè)否定含義的判斷式 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來(lái)查找奇數(shù)則無(wú)需新定義判斷式 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不需要再定義新的否定含義的判斷式了,更簡(jiǎn)便了。
算法庫(kù)還增加了一個(gè)copy_if算法,它相比原來(lái)的copy算法多了一個(gè)判斷式,用起來(lái)更方便了,下面是它的基本用法:
#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()); //根據(jù)條件拷貝 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; }
算法庫(kù)新增了iota用來(lái)方便的生成有序序列,比如我們需要一個(gè)定長(zhǎng)數(shù)組,這個(gè)數(shù)組中的元素都是在某一個(gè)數(shù)值的基礎(chǔ)之上遞增的,那么用iota可以很方便的生成這個(gè)數(shù)組了。下面是它的基本用法:
#include <numeric> #include <array> #include <vector> #include <iostream> using namespace std; int main() { vector<int> v(4) ; //循環(huán)遍歷賦值來(lái)初始化數(shù)組 //for(int i=1; i<=4; i++) //{ // v.push_back(i); //} //直接通過(guò)iota初始化數(shù)組,更簡(jiǎn)潔 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比遍歷賦值來(lái)初始化數(shù)組更簡(jiǎn)潔,需要注意的是iota初始化的序列需要指定大小,如果上面的代碼中:vector<int> v(4) ;沒(méi)有指定初始化大小為4的話,則輸出為空。
算法庫(kù)還新增了一個(gè)同時(shí)獲取最大值和最小值的算法minmax_element,這樣我們?nèi)绻氆@取最大值和最小值的時(shí)候就不用分別調(diào)用max_element和max_element算法了,用起來(lái)會(huì)更方便,minmax_element會(huì)將最小值和最大值的迭代器放到一個(gè)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
算法庫(kù)新增了is_ sorted和is_ sorted_until算法,is_sort用來(lái)判斷某個(gè)序列是否是排好序的,is_sort_until則用來(lái)返回序列中前面已經(jīng)排好序的部分序列。下面是它們的基本用法:
#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
總結(jié):這些新增的算法讓我們用起來(lái)更加簡(jiǎn)便,也增強(qiáng)了代碼的可讀性。
希望本文所述算法對(duì)大家更好的掌握C++11能有所幫助。
相關(guān)文章
C++實(shí)現(xiàn)LeetCode(83.移除有序鏈表中的重復(fù)項(xiàng))
這篇文章主要介紹了C++實(shí)現(xiàn)LeetCode(83.移除有序鏈表中的重復(fù)項(xiàng)),本篇文章通過(guò)簡(jiǎn)要的案例,講解了該項(xiàng)技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下2021-07-07C++面向行輸入之get()與getline()實(shí)例詳解
在c++里當(dāng)我們輸入一個(gè)字符串時(shí)習(xí)慣用cin,但是cin只能讀取一段不含空格的字符串,如果我們需要讀取一段包含空格的字符串時(shí),就需要用到getline()或get(),下面這篇文章主要給大家介紹了關(guān)于C++面向行輸入之get()與getline()的相關(guān)資料,需要的朋友可以參考下2021-10-10初識(shí)C++?Vector模板與實(shí)例化原理
這篇文章主要為大家介紹了初識(shí)C++?Vector模板與實(shí)例化原理,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-12-12C/C++ Qt TreeWidget 嵌套節(jié)點(diǎn)操作使用
本文主要介紹了TreeWidget的如何使用,實(shí)現(xiàn)對(duì)樹(shù)形框多節(jié)點(diǎn)的各種操作,文中通過(guò)示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-11-11C語(yǔ)言中的結(jié)構(gòu)體內(nèi)嵌函數(shù)用法
這篇文章主要介紹了C語(yǔ)言中的結(jié)構(gòu)體內(nèi)嵌函數(shù)用法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-02-02詳解如何在C/C++中測(cè)量一個(gè)函數(shù)或功能的運(yùn)行時(shí)間
本文算是一個(gè)比較完整的關(guān)于在 C/C++ 中測(cè)量一個(gè)函數(shù)或者功能的總結(jié),最后會(huì)演示三種方法的對(duì)比,文章通過(guò)代碼示例給大家介紹的非常詳細(xì),需要的朋友可以參考下2023-12-12C語(yǔ)言驅(qū)動(dòng)開(kāi)發(fā)內(nèi)核特征碼掃描PE代碼段
這篇文章主要為大家介紹了C語(yǔ)言驅(qū)動(dòng)開(kāi)發(fā)內(nèi)核特征碼掃描PE代碼段,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-10-10