日本免费高清视频-国产福利视频导航-黄色在线播放国产-天天操天天操天天操天天操|www.shdianci.com

學(xué)無先后,達(dá)者為師

網(wǎng)站首頁 編程語言 正文

關(guān)于C++中push_back()函數(shù)的用法及代碼實(shí)例_C 語言

作者:明澤. ? 更新時(shí)間: 2022-12-22 編程語言

push_back()函數(shù)的用法

函數(shù)將一個(gè)新的元素加到vector的最后面,位置為當(dāng)前最后一個(gè)元素的下一個(gè)元素

push_back() 在Vector最后添加一個(gè)元素(參數(shù)為要插入的值)

//在vec尾部添加10
vector<int> vec;
vec.push_back(10);
//在容器中添加10
int num = 10;
vector<int> vec;
vec.push_back(num);

或者再string中最后插入一個(gè)字符;

string str;
str.push_back('d');

類似的:

pop_back() //移除最后一個(gè)元素
clear()? //清空所有元素
empty() //判斷vector是否為空,如果返回true為空
erase() // 刪除指定元素

vector是用數(shù)組實(shí)現(xiàn)的,每次執(zhí)行push_back操作,相當(dāng)于底層的數(shù)組實(shí)現(xiàn)要重新分配大小(即先free掉原來的存儲(chǔ),后重新malloc)

函數(shù)名

push_back,算法語言里面的一個(gè)函數(shù)名,如:   

1) c++中的vector頭文件里面就有這個(gè)push_back函數(shù);   

2) 在vector類中作用為在vector尾部加入一個(gè)數(shù)據(jù);   

3) string中也有這個(gè)函數(shù),作用是字符串之后插入一個(gè)字符。?

函數(shù)原型

void push_back(value_type_Ch);

參數(shù) _Ch–>The character to be added to the end of the string.

在vector類中:

 void push_back(const_Ty&_X)
 {
   insert(end(),_X);
 }

在vector<_Bool, _Bool_allocator >類中:

 void push_back(constbool_X)
 {
  insert(end(),_X);
 }

vector容器中添加和刪除元素

添加元素:

方法一:

insert() 插入元素到Vector中

iterator insert( iterator loc, const TYPE &val ); //在指定位置loc前插入值為val的元素,返回指向這個(gè)元素的迭代器
void insert( iterator loc, size_type num, const TYPE &val ); //在指定位置loc前插入num個(gè)值為val的元素
void insert( iterator loc, input_iterator start, input_iterator end ); //在指定位置loc前插入?yún)^(qū)間[start, end)的所有元素

方法二:

push_back() 在Vector最后添加一個(gè)元素(參數(shù)為要插入的值)

刪除元素:

方法一:

clear() 清空所有元素

empty() 判斷Vector是否為空(返回true時(shí)為空)

方法二:

erase() 刪除指定元素 (可以用指針來代替迭代器)

iterator erase( iterator loc ); //要?jiǎng)h除元素的迭代器
iterator erase( iterator start, iterator end ); //要?jiǎng)h除的第一個(gè)元素的迭代器,要?jiǎng)h除的第二個(gè)元素的迭代器

方法三:

pop_back() 移除最后一個(gè)元素

方法四:

可以采用通用算法remove()來刪除vector容器中的元素,?不同的是,采用 remove?一般情況下不會(huì)改變?nèi)萜鞯拇笮。鴓op_back()與erase()等成員函數(shù)會(huì)改變?nèi)萜鞯拇笮 ?/p>

例如:

#include "stdafx.h"
#include <iostream>
#include <vector>
#include <algorithm>
#include <string>
#include <list>
using namespace std;
 
void PrintInt( const int &nData)
{
cout<<nData<<endl;
}
 
int _tmain( int argc, _TCHAR* argv[])
{
vector< int > vecInt;
for ( int i=0; i<10;++i)
{
vecInt.push_back(i);
}
cout<< " 向量中的內(nèi)容為:" <<endl;
for_each(vecInt.begin(),vecInt.end(),PrintInt);
cout<< "vector contains " <<vecInt.size()<< " elements" <<endl;
vecInt.pop_back(); // 刪除最后一個(gè)元素
cout<< " 刪除最后一個(gè)元素后,vector contains " <<vecInt.size()<< " elements" <<endl;
vector< int >::iterator k = vecInt.begin();
vecInt.erase(k); // 刪除第一個(gè)元素
//vecInt.erase(k); // 迭代器k 已經(jīng)失效,會(huì)出錯(cuò)
cout<< " 刪除第一個(gè)元素后,vector contains " <<vecInt.size()<< " elements" <<endl;
//vecInt.erase(vecInt.begin(),vecInt.end()); // 刪除所有元素
//cout<<" 刪除所有元素后,vector contains "<<vecInt.size()<<"elements"<<endl; // 輸出為0
vector< int >::iterator vecNewEnd =remove(vecInt.begin(),vecInt.end(),5); // 刪除元素
cout<< " 刪除元素后,vector contains " <<vecInt.size()<< " elements" <<endl;
cout<< " 向量開始到新結(jié)束為止的元素:" <<endl;
for_each(vecInt.begin(),vecNewEnd,PrintInt);
cout<< " 向量中的元素:" <<endl;
for_each(vecInt.begin(),vecInt.end(),PrintInt);
return 0;

總結(jié)

原文鏈接:https://blog.csdn.net/qq_36955294/article/details/110954308

欄目分類
最近更新