這篇文章給大家分享的是有關(guān)C++中push方法與push_back方法有什么區(qū)別的內(nèi)容。小編覺得挺實(shí)用的,因此分享給大家做個(gè)參考,一起跟隨小編過來看看吧。
【正文】
push_back 方法介紹
vector::void push_back (const value_type& val);
vector::void push_back (value_type&& val);
該函數(shù)將一個(gè)新的元素加到vector的最后面,位置為當(dāng)前最后一個(gè)元素的下一個(gè)元素,新的元素的值是val的拷貝(或者是移動(dòng)拷貝)
vector 常見方法介紹
(1)vector< 類型 > 標(biāo)識(shí)符 ;
(2)vector< 類型 > 標(biāo)識(shí)符(較大容量) ;(3)vector< 類型 > 標(biāo)識(shí)符(較大容量,初始所有值);(4) int i[4] = {12,3,4,5};vector< 類型 > vi(i , i+2); //得到i索引值為3以后的值 ; (5)vector< vector<int> > //vi 定義2維的容器;記得一定要有空格,不然可能會(huì)報(bào)錯(cuò)
vector< int > line // 在使用的時(shí)候一定要首先將vi個(gè)行進(jìn)行初始化; for(int i = 0 ; i < 10 ; i ++) { vector.push_back(line); }
vector 定義二維數(shù)組,長度可以不預(yù)先確定。(6)C++ vector排序
vector< int > vi ; vi.push_back(1); vi.push_back(3); vi.push_back(0); sort(vi.begin() , vi.end()); /// /從小到大 reverse(vi.begin(),vi.end()); /// 從大到小
(7)順序訪問
vector < int > vi ; for( int i = 0 ; i < 10 ; i ++) { vi.push_back(i); } for(int i = 0 ; i < 10 ; i ++) /// 第一種調(diào)用方法 { cout <<vi[i] <<" " ; } for(vector<int>::iterator it = vi.begin() ;it !=vi.end() ; it++) ///第二種調(diào)用方法 { cout << *it << " " ; }
(8)查找
vector < int > vi ; for( int i = 0 ; i < 10 ; i ++) { vector.push_back(i); } vector < int >::interator it = find(vi.begin() , vi.end(),3) ; cout << *it << endl ; ///返回容器內(nèi)找到值的位置。
(9)使用數(shù)組對C++ vector進(jìn)行初始化
int i[10] ={1,2,3,4,5,6,7,78,8} ; ///第一種 vector<int> vi(i+1,i+3); ///從第2個(gè)元素到第3個(gè)元素 for(vector <int>::interator it = vi.begin() ; it != vi.end() ; it++) { cout << *it <<" " ; }
(10) 結(jié)構(gòu)體的 vector
struct temp { public : string str ; public : int id ; }tmp;int main() { vector <temp> t ; temp w1 ; w1.str = "Hello world" ; w1.id = 1 ; t.push_back(t1); cout << w1.str << "," <<w1.id <<endl ; return 0 ; }
push 函數(shù)介紹
stack::push();//在棧頂增加元素queue::push();//將x 接到隊(duì)列的末端。
stack與queue常見方法介紹
1、stack
stack 模板類的定義在<stack>頭文件中。
stack 模板類需要兩個(gè)模板參數(shù),一個(gè)是元素類型,一個(gè)容器類型,但只有元素類型是必要的,在不指定容器類型時(shí),默認(rèn)的容器類型為deque。
定義stack 對象的示例代碼如下:
stack<int> s1;
stack<string> s2;
stack 的基本操作有:
入棧,如例:s.push();在棧頂增加元素
出棧,如例:s.pop();注意,出棧操作只是刪除棧頂元素,并不返回該元素。
訪問棧頂,如例:s.top()
判斷???,如例:s.empty(),當(dāng)??諘r(shí),返回true。
訪問棧中的元素個(gè)數(shù),如例:s.size()。
2、queue
queue 模板類的定義在<queue>頭文件中。
與stack 模板類很相似,queue 模板類也需要兩個(gè)模板參數(shù),一個(gè)是元素類型,一個(gè)容器類型,元素類型是必要的,容器類型是可選的,默認(rèn)為deque 類型。
定義queue 對象的示例代碼如下:
queue<int> q1;
queue<double> q2;
queue 的基本操作有:
入隊(duì),如例:q.push(x); 將x 接到隊(duì)列的末端。
出隊(duì),如例:q.pop(); 彈出隊(duì)列的第一個(gè)元素,注意,并不會(huì)返回被彈出元素的值。
訪問隊(duì)首元素,如例:q.front(),即最早被壓入隊(duì)列的元素。
訪問隊(duì)尾元素,如例:q.back(),即最后被壓入隊(duì)列的元素。
判斷隊(duì)列空,如例:q.empty(),當(dāng)隊(duì)列空時(shí),返回true。
訪問隊(duì)列中的元素個(gè)數(shù),如例:q.size()
感謝各位的閱讀!關(guān)于“C++中push方法與push_back方法有什么區(qū)別”這篇文章就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,讓大家可以學(xué)到更多知識(shí),如果覺得文章不錯(cuò),可以把它分享出去讓更多的人看到吧!
當(dāng)前文章:C++中push方法與push_back方法有什么區(qū)別-創(chuàng)新互聯(lián)
鏈接URL:http://jinyejixie.com/article18/djchgp.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供建站公司、企業(yè)網(wǎng)站制作、網(wǎng)站策劃、全網(wǎng)營銷推廣、定制網(wǎng)站、定制開發(fā)
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)
猜你還喜歡下面的內(nèi)容