この記事では、C++ の STL リストの詳細な説明と簡単な例を主に紹介します。必要な方は参考にしてください。
C++ の STL リストの詳細な説明
リスト: 内部実装は 2 つです。効率的なウェイリンクリスト 挿入と削除を実行しますが、ランダムアクセスは実行できません
#include "stdafx.h"
#include <iostream>
#include <list>
#include <iterator>
#include <algorithm>
using namespace std;
const int num[5] = {1,3,2,4,5};
bool status(const int & value)
{
return value>6?true:false;
}
int _tmain(int argc, _TCHAR* argv[])
{
list<int> list1;
copy(num,num+5,back_insert_iterator<list<int>>(list1));
copy(list1.begin(),list1.end(),ostream_iterator<int>(cout," "));
cout<<endl;
list1.sort(greater<int>());//5 4 3 2 1
copy(list1.begin(),list1.end(),ostream_iterator<int>(cout," "));
cout<<endl;
list<int>::iterator it = list1.begin();
while (it != list1.end())
{
(*it) += 2;
it++;
}
//7 6 5 4 3
list<int>::reverse_iterator re_it = list1.rbegin();
cout<<"从后向前输出: ";
while (re_it != list1.rend())
{
cout<<*re_it<<" ";
re_it++;
}
cout<<endl;
list1.reverse();// 3 4 5 6 7
list1.push_back(8);//3 4 5 6 7 8
list1.pop_front();//4 5 6 7 8
list1.remove(6);//4 5 7 8
list1.remove_if(status);// 4 5
list1.resize(4);// 4 5 0 0
list1.resize(6,1);// 4 5 0 0 1 1
list1.unique();//4 5 0 1
copy(list1.begin(),list1.end(),ostream_iterator<int>(cout," "));
cout<<endl;
list1.clear();
cout<<"当前list1含有元素个数:"<<list1.size()<<endl;
list1.push_back(7);//list1:7
list<int> list2(3,2);//2 2 2
list2.merge(list1,greater<int>());//list2: 7 2 2 2
list2.insert(++list2.begin(),3);//list2: 7 3 2 2 2
list2.swap(list1);//list1:7 3 2 2 2 list2:empty
list1.erase(++list1.begin(),list1.end());// 7
copy(list1.begin(),list1.end(),ostream_iterator<int>(cout," "));
cout<<endl;
system("pause");
}
実行結果の画像:
3.メソッド
説明 | コンストラクター |
コンストラクター |
デストラクター |
デストラクター | operator= |
assignment オーバーロードされた演算子 | assign |
値を代入 | front |
最初の要素への参照を返す | 戻る |
最後を返すelement | begin |
の参照は、最初の要素のイテレータを返します | end |
は、最後の要素の次の位置のイテレータを返します | rbegin |
後方ポインタを返します reverse_iterator | rend |
リンクされたリストの最初の要素の次の位置にある reverse_iterator を返します | push_back |
データを追加するリンクリストに Tail | push_front |
リンクリストの先頭にデータを追加 | pop_back |
リンクリストの末尾の要素を削除 | pop_front |
リンクされたリストの先頭を削除 1つの要素 | clear |
すべての要素を削除 | erase |
要素または要素の範囲を削除する(オーバーロード2つ) |
remove |
リンクリスト内の値が一致する要素を削除(一致する要素はすべて削除) | remove_if |
条件を満たす要素を削除(リンク リストを 1 回スキャンします)、パラメーターはカスタム コールバック関数です | empty |
リンク リストが空かどうかを判断します | max_size |
可能な最大長を返しますリンクされたリスト | size |
リンクされたリスト内の要素の数を返す | resize |
リンクされたリストの長さを再定義する(2つのオーバーロードされた関数) | reverse |
リンクされたリストを反転 | sort |
リンクされたリストをデフォルトの昇順に並べ替えます |
merge |
2つの順序付けされたリンクリストを結合して順序付けますsplice | 組み合わせの後に2つのリンクリスト(3つのオーバーロードされた関数)を組み合わせて、2番目のリンクリストがクリアされます。 Position (3 つのオーバーロード関数) |
swap | 2 つのリンクされたリストを交換します (2 つのオーバーロード関数) |
一意の | 隣接する重複要素を削除します |
以上がC++ での STL リストの使用方法の例の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。