日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

续vector

發(fā)布時(shí)間:2025/4/16 编程问答 23 豆豆
生活随笔 收集整理的這篇文章主要介紹了 续vector 小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.
//c.push_back(elem)在尾部插入一個(gè)elem數(shù)據(jù)。 vector<int> v; v.push_back(1); //c.pop_back()刪除末尾的數(shù)據(jù)。vector<int> v;v.pop_back();//c.assign(beg,end)將[beg,end)一個(gè)左閉右開區(qū)間的數(shù)據(jù)賦值給c。 vector<int> v1,v2; v1.push_back(10); v1.push_back(20); v2.push_back(30); v2.assign(v1.begin(),v1.end()); //c.assign (n,elem)將n個(gè)elem的拷貝賦值給c。 vector<int> v; v.assign(5,10);//往v里放5個(gè)10,默認(rèn)為從v.begin()開始放,則會(huì)把原先v容器中的值給覆蓋掉//c.at(int index)傳回索引為index的數(shù)據(jù),如果index越界,拋出out_of_range異常。下標(biāo)從0開使 vecto<int> v; cout << v.at(2) << endl;//打印vector中下標(biāo)是2的數(shù)據(jù) //c.begin()返回指向第一個(gè)數(shù)據(jù)的迭代器。 //c.end()返回指向最后一個(gè)數(shù)據(jù)之后的迭代器。 vector<int> v; v.push_back(1); v.push_back(2); v.push_back(3); vector<int>::iterator it; for(it = v.begin();it!=v.end();it++)cout << *it << "\t";cout << endl; //c.rbegin()返回逆向隊(duì)列的第一個(gè)數(shù)據(jù),即c容器的最后一個(gè)數(shù)據(jù)。 //c.rend()返回逆向隊(duì)列的最后一個(gè)數(shù)據(jù)的下一個(gè)位置,即c容器的第一個(gè)數(shù)據(jù)再往前的一個(gè)位置。 vector<int> v; v.push_back(1); v.push_back(2); v.push_back(3); vector<int>::reverse_iterator it; for(it = v.rbegin();it!=v.rend();it++)cout << *it << "\t"; cout << endl; //c.capacity()返回容器中數(shù)據(jù)個(gè)數(shù),翻倍增長。 vector<int> v; v.push_back(1); cout << v.capacity() << endl; // 1 v.push_back(2); cout << v.capacity() << endl; // 2 v.push_back(3); cout << v.capacity() << endl; // 4 //c.clear()移除容器中的所有數(shù)據(jù)。 vector<int>::iterator it; for(it = v.begin();it!=v.end();it++)cout << *it << "\t"; v.clear(); for(it = v.begin();it!=v.end();it++)cout << *it << "\t"; cout << endl; //c.empty()判斷容器是否為空。 vector<int> v; v.push_back(1); v.push_back(2); v.push_back(3); if(!v.empty())cout << "v is not empty!" << endl; //c.erase(pos)刪除pos位置的數(shù)據(jù),傳回下一個(gè)數(shù)據(jù)的位置。 vector<int> v; v.push_back(1); v.push_back(2); v.push_back(3); v.erase(v.begin()); //c.erase(beg,end)刪除[beg,end)區(qū)間的數(shù)據(jù),傳回下一個(gè)數(shù)據(jù)的位置。 vector<int> v; v.push_back(1); v.push_back(2); v.push_back(3); v.erase(v.begin(),v.end()); //c.front()返回第一個(gè)數(shù)據(jù)。 //c.back()傳回最后一個(gè)數(shù)據(jù),不檢查這個(gè)數(shù)據(jù)是否存在。 vector<int> v; v.push_back(1); v.push_back(2); v.push_back(3); if(!vec.empty())cout << “the first number is:” << v.front() << endl;cout << “the last number is:” << v.back() << endl; //c.insert(pos,elem) 在pos位置插入一個(gè)elem的拷貝,返回插入的值的迭代器。 //c.insert(pos,n,elem)在pos位置插入n個(gè)elem的數(shù)據(jù),無返回值。 //c.insert(pos,beg,end)在pos位置插入在[beg,end)區(qū)間的數(shù)據(jù),無返回值。 vector<int> v; v.insert(v.begin(),10); v.insert(v.begin(),2,20); v.insert(v.begin(),v1.begin(),v1.begin()+2);/*c.size()返回容器中實(shí)際數(shù)據(jù)的個(gè)數(shù)。 c.resize(num)重新指定隊(duì)列的長度。(往往用來增加vector的長度,小->大 ok 大->小 沒用!) c.reserve()保留適當(dāng)?shù)娜萘俊?針對(duì)resize()和reserver()做一點(diǎn)分析:reserve是容器預(yù)留空間,但并不真正創(chuàng)建元素對(duì)象,在創(chuàng)建對(duì)象之前,不能引用容器內(nèi)的元素,因此當(dāng)加入新的元素時(shí),需要用push_back()/insert()函數(shù)。resize是改變?nèi)萜鞯拇笮?#xff0c;并且創(chuàng)建對(duì)象,因此,調(diào)用這個(gè)函數(shù)之后,就可以引用容器內(nèi)的對(duì)象了,因此當(dāng)加入新的元素時(shí),用operator[]操作符,或者用迭代器來引用元素對(duì)象。再者,兩個(gè)函數(shù)的形式是有區(qū)別的,reserve函數(shù)之后一個(gè)參數(shù),即需要預(yù)留的容器的空間;resize函數(shù)可以有兩個(gè)參數(shù),第一個(gè)參數(shù)是容器新的大小,第二個(gè)參數(shù)是要加入容器中的新元素,如果這個(gè)參數(shù)被省略,那么就調(diào)用元素對(duì)象的默認(rèn)構(gòu)造函數(shù)。reserve只是保證vector的空間大小(capacity)最少達(dá)到它的參數(shù)所指定的大小n。在區(qū)間[0, n)范圍內(nèi),如果下標(biāo)是index,vector[index]這種訪問有可能是合法的,也有可能是非法的,視具體情況而定。resize和reserve接口的共同點(diǎn)是它們都保證了vector的空間大小(capacity)最少達(dá)到它的參數(shù)所指定的大小。 c.max_size()返回容器能容量的最大數(shù)量。*///c1.swap(c2)將c1和c2交換。 //swap(c1,c2)同上。 vector<int> v1,v2,v3; v1.push_back(10); v2.swap(v1); swap(v3,v1); /* vector<type>c;創(chuàng)建一個(gè)空的vector容器。 vector<type> c1(c2);復(fù)制一個(gè)vector。 vector<type> c(n);創(chuàng)建一個(gè)vector,含有n個(gè)數(shù)據(jù),數(shù)據(jù)均以缺省構(gòu)造產(chǎn)生,即全0; vector<type> c(n,elem)創(chuàng)建一個(gè)vector,含有n個(gè)elem的拷貝數(shù)據(jù)。 vector<type> c(beg,end)創(chuàng)建一個(gè)以[beg,end)區(qū)間的vector。 ~vector<type>() 銷毀所有數(shù)據(jù),施放內(nèi)存。 */ 自:http://www.cnblogs.com/scandy-yuan/archive/2013/01/07/2849735.html

總結(jié)

以上是生活随笔為你收集整理的续vector的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。