c++11新增的便利算法實(shí)例分析
C++是一門應(yīng)用非常廣泛的程序設(shè)計(jì)語言,而c++11則新增加了一些便利的算法,這些新增的算法使我們的代碼寫起來更簡潔方便,本文列舉一些常用的新增算法,算是做個總結(jié)分析,更多的新增算法讀者可以參考: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:檢查區(qū)間[first, last)中是否所有的元素都滿足一元判斷式p,所有的元素都滿足條件返回true,否則返回false。
② any_of:檢查區(qū)間[first, last)中是否至少有一個元素都滿足一元判斷式p,只要有一個元素滿足條件就返回true,否則返回true。
③ none_of:檢查區(qū)間[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也可以實(shí)現(xiàn)find_if_not的功能,只需要將判斷式改為否定的判斷式即可,現(xiàn)在新增了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來查找奇數(shù)則需要重新寫一個否定含義的判斷式
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來查找奇數(shù)則無需新定義判斷式
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());
//根據(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;
}
算法庫新增了iota用來方便的生成有序序列,比如我們需要一個定長數(shù)組,這個數(shù)組中的元素都是在某一個數(shù)值的基礎(chǔ)之上遞增的,那么用iota可以很方便的生成這個數(shù)組了。下面是它的基本用法:
#include <numeric>
#include <array>
#include <vector>
#include <iostream>
using namespace std;
int main()
{
vector<int> v(4) ;
//循環(huán)遍歷賦值來初始化數(shù)組
//for(int i=1; i<=4; i++)
//{
// v.push_back(i);
//}
//直接通過iota初始化數(shù)組,更簡潔
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比遍歷賦值來初始化數(shù)組更簡潔,需要注意的是iota初始化的序列需要指定大小,如果上面的代碼中:vector<int> v(4) ;沒有指定初始化大小為4的話,則輸出為空。
算法庫還新增了一個同時獲取最大值和最小值的算法minmax_element,這樣我們?nèi)绻氆@取最大值和最小值的時候就不用分別調(diào)用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則用來返回序列中前面已經(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é):這些新增的算法讓我們用起來更加簡便,也增強(qiáng)了代碼的可讀性。
希望本文所述算法對大家更好的掌握C++11能有所幫助。
相關(guān)文章
淺談C語言函數(shù)調(diào)用參數(shù)壓棧的相關(guān)問題
下面小編就為大家?guī)硪黄獪\談C語言函數(shù)調(diào)用參數(shù)壓棧的相關(guān)問題。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2016-09-09
C++實(shí)現(xiàn)圖書管理系統(tǒng)簡易版
這篇文章主要為大家詳細(xì)介紹了C++實(shí)現(xiàn)圖書管理系統(tǒng)簡易版,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下2022-03-03
深入理解c++實(shí)現(xiàn)Qt信號和槽機(jī)制
信號和槽機(jī)制是 Qt 的核心機(jī)制,可以讓編程人員將互不相關(guān)的對象綁定在一起,實(shí)現(xiàn)對象之間的通信,本文就來深入理解c++實(shí)現(xiàn)Qt信號和槽機(jī)制,感興趣的可以了解一下2023-08-08
C語言手撕一個Hash表(HashTable)實(shí)例代碼
哈希表(HashTable)是一種非常重要的數(shù)據(jù)結(jié)構(gòu),它可以在常量時間內(nèi)進(jìn)行插入、查找和刪除操作,下面這篇文章主要給大家介紹了關(guān)于C語言手撕一個Hash表(HashTable)的相關(guān)資料,需要的朋友可以參考下2023-03-03
C語言實(shí)現(xiàn)單位車輛調(diào)度管理
這篇文章主要為大家詳細(xì)介紹了C語言實(shí)現(xiàn)單位車輛調(diào)度管理,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下2022-03-03

