欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

C++中 STL list詳解及簡單實例

 更新時間:2017年04月11日 11:56:52   投稿:lqh  
這篇文章主要介紹了C++中 STL list詳解及簡單實例的相關資料,需要的朋友可以參考下

C++中 STL list詳解

1、List: 內部實現是一個雙向鏈表,可以高效的進行插入刪除,但不能夠進行隨機訪問

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<<"當前l(fā)ist1含有元素個數:"<<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、List 方法 

list成員

說明

constructor

構造函數

destructor

析構函數

operator=

賦值重載運算符

assign

分配值

front

返回第一個元素的引用

back

返回最后一元素的引用

begin

返回第一個元素的iterator

end

返回最后一個元素的下一位置的iterator

rbegin

返回鏈表最后一元素的后向指針reverse_iterator

rend

返回鏈表第一元素的下一位置的reverse_iterator

push_back

增加一個數據到鏈表尾

push_front

增加一個數據到鏈表頭

pop_back

刪除鏈表尾的一個元素

pop_front

刪除鏈表頭的一元素

clear

刪除所有元素

erase

刪除一個元素或一個區(qū)域的元素(兩個重載)

remove 

刪除鏈表中匹配值的元素(匹配元素全部刪除)

remove_if

刪除條件滿足的元素(遍歷一次鏈表),參數為自定義的回調函數

empty

判斷是否鏈表為空

max_size

返回鏈表最大可能長度

size

返回鏈表中元素個數

resize

重新定義鏈表長度(兩重載函數)

reverse

反轉鏈表

sort 

對鏈表排序,默認升序

merge

合并兩個有序鏈表并使之有序

splice 

對兩個鏈表進行結合(三個重載函數) 結合后第二個鏈表清空

insert

在指定位置插入一個或多個元素(三個重載函數)

swap

交換兩個鏈表(兩個重載)

unique 

刪除相鄰重復元素 


感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!

相關文章

  • C/C++內存管理之new與delete的使用及原理解析

    C/C++內存管理之new與delete的使用及原理解析

    這篇文章主要介紹了C/C++內存管理之new與delete的使用及原理解析,本文通過實例代碼圖文相結合給大家介紹的非常詳細,感興趣的朋友跟隨小編一起看看吧
    2024-08-08
  • c++ *運算符重載

    c++ *運算符重載

    運算符重載重載運算符是C++ 的一個重要特性,使用運算符重載, 的一個重要特性,使用運算符重載, 重載運算符是程序員可以把C++ 運算符的定義擴展到運算分量是對象
    2014-09-09
  • C++中explict關鍵字用法

    C++中explict關鍵字用法

    這篇文章主要介紹了C++中explict關鍵字用法的相關資料,本文介紹的非常詳細,具有參考借鑒價值,感興趣的朋友一起學習吧
    2016-05-05
  • C++對象的動態(tài)建立與釋放詳解

    C++對象的動態(tài)建立與釋放詳解

    我們知道可以用new運算符可以動態(tài)的分配內存,用delete運算符可以釋放這些內存。當我們使用new運算符動態(tài)的分配一個內存之后,會自動返回一個該內存段的起始地址,也就是指針。
    2013-10-10
  • C\C++實現讀寫二進制文件的方法詳解

    C\C++實現讀寫二進制文件的方法詳解

    這篇文章主要為大家詳細介紹了C\C++實現讀寫二進制文件的方法,文中的示例代碼講解詳細,具有一定的借鑒價值,感興趣的小伙伴可以了解一下
    2023-03-03
  • 利用Matlab制作一款刮刮樂抽獎特效

    利用Matlab制作一款刮刮樂抽獎特效

    七夕節(jié)還不知道送啥,教你用MATLAB制作一款刮刮樂抽獎特效,讓她的手氣決定她的禮物。文中的示例代碼講解詳細,感興趣的小伙伴可以了解一下
    2022-03-03
  • C++實現打印虛函數表的地址

    C++實現打印虛函數表的地址

    對于存在虛函數的類,如何打印虛函數表的地址,并利用這個虛函數表的地址來執(zhí)行該類中的虛函數呢,下面小編就來和大家一起簡單聊聊吧
    2023-07-07
  • C語言解字符串逆序和單向鏈表逆序問題的代碼示例

    C語言解字符串逆序和單向鏈表逆序問題的代碼示例

    這篇文章主要介紹了C語言解字符串逆序和單向鏈表逆序問題的代碼示例,求逆序也是考研和面試中的基礎算法題類型,需要的朋友可以參考下
    2016-06-06
  • 詳解C++中二進制求補運算符與下標運算符的用法

    詳解C++中二進制求補運算符與下標運算符的用法

    這篇文章主要介紹了C++中二進制求補運算符與下標運算符的用法,是C++入門學習中的基礎知識,需要的朋友可以參考下
    2016-01-01
  • C++浮點數類型詳情

    C++浮點數類型詳情

    這篇文章主要介紹了C++浮點數類型,浮點數是C++的第二組基本類型,它能夠表示帶小數部分的數字。不僅如此,浮點數的范圍也比int更大,可以表示更大范圍的數字。下面來我們大家一起來學習學習內容
    2021-11-11

最新評論