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

C++中 STL list詳解及簡(jiǎn)單實(shí)例

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

C++中 STL list詳解

1、List: 內(nèi)部實(shí)現(xiàn)是一個(gè)雙向鏈表,可以高效的進(jìn)行插入刪除,但不能夠進(jìn)行隨機(jī)訪問(wèn)

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<<"當(dāng)前l(fā)ist1含有元素個(gè)數(shù):"<<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"); 
} 

運(yùn)行結(jié)果圖片:


3、List 方法 

list成員

說(shuō)明

constructor

構(gòu)造函數(shù)

destructor

析構(gòu)函數(shù)

operator=

賦值重載運(yùn)算符

assign

分配值

front

返回第一個(gè)元素的引用

back

返回最后一元素的引用

begin

返回第一個(gè)元素的iterator

end

返回最后一個(gè)元素的下一位置的iterator

rbegin

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

rend

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

push_back

增加一個(gè)數(shù)據(jù)到鏈表尾

push_front

增加一個(gè)數(shù)據(jù)到鏈表頭

pop_back

刪除鏈表尾的一個(gè)元素

pop_front

刪除鏈表頭的一元素

clear

刪除所有元素

erase

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

remove 

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

remove_if

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

empty

判斷是否鏈表為空

max_size

返回鏈表最大可能長(zhǎng)度

size

返回鏈表中元素個(gè)數(shù)

resize

重新定義鏈表長(zhǎng)度(兩重載函數(shù))

reverse

反轉(zhuǎn)鏈表

sort 

對(duì)鏈表排序,默認(rèn)升序

merge

合并兩個(gè)有序鏈表并使之有序

splice 

對(duì)兩個(gè)鏈表進(jìn)行結(jié)合(三個(gè)重載函數(shù)) 結(jié)合后第二個(gè)鏈表清空

insert

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

swap

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

unique 

刪除相鄰重復(fù)元素 


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

相關(guān)文章

  • C/C++內(nèi)存管理之new與delete的使用及原理解析

    C/C++內(nèi)存管理之new與delete的使用及原理解析

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

    c++ *運(yùn)算符重載

    運(yùn)算符重載重載運(yùn)算符是C++ 的一個(gè)重要特性,使用運(yùn)算符重載, 的一個(gè)重要特性,使用運(yùn)算符重載, 重載運(yùn)算符是程序員可以把C++ 運(yùn)算符的定義擴(kuò)展到運(yùn)算分量是對(duì)象
    2014-09-09
  • C++中explict關(guān)鍵字用法

    C++中explict關(guān)鍵字用法

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

    C++對(duì)象的動(dòng)態(tài)建立與釋放詳解

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

    C\C++實(shí)現(xiàn)讀寫二進(jìn)制文件的方法詳解

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

    利用Matlab制作一款刮刮樂(lè)抽獎(jiǎng)特效

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

    C++實(shí)現(xiàn)打印虛函數(shù)表的地址

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

    C語(yǔ)言解字符串逆序和單向鏈表逆序問(wèn)題的代碼示例

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

    詳解C++中二進(jìn)制求補(bǔ)運(yùn)算符與下標(biāo)運(yùn)算符的用法

    這篇文章主要介紹了C++中二進(jìn)制求補(bǔ)運(yùn)算符與下標(biāo)運(yùn)算符的用法,是C++入門學(xué)習(xí)中的基礎(chǔ)知識(shí),需要的朋友可以參考下
    2016-01-01
  • C++浮點(diǎn)數(shù)類型詳情

    C++浮點(diǎn)數(shù)類型詳情

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

最新評(píng)論