C++?list容器merge算法的使用以及注意事項
更新時間:2024年04月24日 08:40:41 作者:Never?mind
這篇文章主要介紹了C++?list容器merge算法的使用以及注意事項,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
list容器merge算法的使用注意事項
C++的list容器merge算法有多種形式,這里僅討論一下兩種:
(1) void merge(list &x)
該算法將一個有序list容器加入另一個有序list容器中,且兩個list容器必須都為逆序或順序,這是很容易不注意導致報錯的主要原因。
list lst1{ 111,222,333,444 };//順序 list lst2{ 2411,4,3,2,1 };//逆序 lst1.merge(lst2); for (auto beg = lst1.begin(); beg != lst1.end(); ++beg) cout << *beg << " "; cout << endl;
(2) void merge(lst2,comp)
該算法可以自定義比較類型,需要一個能返回bool型的predict。
bool mycomparison (double first, double second) { return ( int(first)<int(second) ); } int main () { std::list first, second; first.push_back (3.1); first.push_back (2.2); first.push_back (2.9); second.push_back (3.7); second.push_back (7.1); second.push_back (1.4); first.sort(); second.sort(); first.merge(second); //使用merge后插入的list都為空 second.push_back (2.1); first.merge(second,mycomparison); std::cout << “first contains:”; for (std::list::iterator it=first.begin(); it!=first.end(); ++it) std::cout << ' ' << *it; std::cout << ‘\n'; return 0; }
需要注意的是:
- merge默認是使用<運算符
- 如果通過pred修改為使用>運算符時
- 相應(yīng)的兩個list容器中的元素也應(yīng)該是按照從大到小的順序排列
- 否則會觸發(fā)錯誤
總結(jié)
以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
探討:C++實現(xiàn)鏈式二叉樹(用非遞歸方式先序,中序,后序遍歷二叉樹)
本篇文章是對用C++實現(xiàn)鏈式二叉樹(用非遞歸方式先序,中序,后序遍歷二叉樹)的方法進行了詳細的分析介紹,需要的朋友參考下2013-05-05