关于C++中push_back()函数的用法及代码实例

目录
  • push_back()函数的用法
  • vector容器中添加和删除元素
  • 总结

push_back()函数的用法

函数将一个新的元素加到vector的最后面,位置为当前最后一个元素的下一个元素

push_back() 在Vector最后添加一个元素(参数为要插入的值)

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

或者再string中最后插入一个字符;

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

类似的:

pop_back() //移除最后一个元素
clear()  //清空所有元素
empty() //判断vector是否为空,如果返回true为空
erase() // 删除指定元素

vector是用数组实现的,每次执行push_back操作,相当于底层的数组实现要重新分配大小(即先free掉原来的存储,后重新malloc)

函数名

push_back,算法语言里面的一个函数名,如:   

1) c++中的vector头文件里面就有这个push_back函数;   

2) 在vector类中作用为在vector尾部加入一个数据;   

3) string中也有这个函数,作用是字符串之后插入一个字符。

函数原型

void push_back(value_type_Ch);

参数 _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的元素,返回指向这个元素的迭代器
void insert( iterator loc, size_type num, const TYPE &val ); //在指定位置loc前插入num个值为val的元素
void insert( iterator loc, input_iterator start, input_iterator end ); //在指定位置loc前插入区间[start, end)的所有元素

方法二:

push_back() 在Vector最后添加一个元素(参数为要插入的值)

删除元素:

方法一:

clear() 清空所有元素

empty() 判断Vector是否为空(返回true时为空)

方法二:

erase() 删除指定元素 (可以用指针来代替迭代器)

iterator erase( iterator loc ); //要删除元素的迭代器
iterator erase( iterator start, iterator end ); //要删除的第一个元素的迭代器,要删除的第二个元素的迭代器

方法三:

pop_back() 移除最后一个元素

方法四:

可以采用通用算法remove()来删除vector容器中的元素, 不同的是,采用 remove 一般情况下不会改变容器的大小,而pop_back()与erase()等成员函数会改变容器的大小。

例如:

#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<< " 向量中的内容为:" <<endl;
for_each(vecInt.begin(),vecInt.end(),PrintInt);
cout<< "vector contains " <<vecInt.size()<< " elements" <<endl;
vecInt.pop_back(); // 删除最后一个元素
cout<< " 删除最后一个元素后,vector contains " <<vecInt.size()<< " elements" <<endl;
vector< int >::iterator k = vecInt.begin();
vecInt.erase(k); // 删除第一个元素
//vecInt.erase(k); // 迭代器k 已经失效,会出错
cout<< " 删除第一个元素后,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<< " 向量开始到新结束为止的元素:" <<endl;
for_each(vecInt.begin(),vecNewEnd,PrintInt);
cout<< " 向量中的元素:" <<endl;
for_each(vecInt.begin(),vecInt.end(),PrintInt);
return 0;

总结

到此这篇关于C++中push_back()函数用法的文章就介绍到这了,更多相关C++ push_back()函数用法内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

(0)

相关推荐

  • C++ push_back()函数使用详解

    最近在学习Opencv,用C++写程序,做了一个虚拟画笔的项目,即通过摄像头采集视频图像信息,识别视频中的画笔,并画笔在空中的划痕显示在视频图像上.在进行到划痕显示的,由于视频是实时采集的,检测到的画笔位置坐标会不断更新,但是现在需要将划痕留在视频图像上. 经过查阅,push_back()函数可以实现这个功能,首先他存在于vector头文件中,显然和vector有关,其功能是为指定vector容器尾部添加数据,并且该vector的容量随压入数据不断扩大,新压入数据和旧数据共存不会溢出.为了更加形

  • C++ push方法与push_back方法的使用与区别

    [摘要] push与push_back是STL中常见的方法,都是向数据结构中添加元素.初识STL,对于添加元素的方法以产生混淆,这里暂对两种方法作出比较分析.此外,本文还将简述push对应的stack与queue系列,常见方法的介绍,以及与push_back相对应的vector系列常见方法介绍.详见下文. list 也是使用 push_back . [正文] push_back 方法介绍 vector::void push_back (const value_type& val); vector

  • C++ 中"emplace_back" 与 "push_back" 的区别

     C++ 中"emplace_back" 与 "push_back" 的区别 emplace_back和push_back都是向容器内添加数据. 对于在容器中添加类的对象时, 相比于push_back,emplace_back可以避免额外类的复制和移动操作. "emplace_back avoids the extra copy or move operation required when using push_back." 参见: http:

  • C++ push方法与push_back方法常见方法介绍

    目录 [摘要] [正文] 1.stack 2.queue [摘要] push与push_back是STL中常见的方法,都是向数据结构中添加元素.初识STL,对于添加元素的方法以产生混淆,这里暂对两种方法作出比较分析.此外,本文还将简述push对应的stack与queue系列,常见方法的介绍,以及与push_back相对应的vector系列常见方法介绍,详见下文. [正文] push_back 方法介绍 vector::void push_back (const value_type& val);

  • C++实现栈的操作(push和pop)

    目录 栈的操作(push和pop) 栈的组织形式 栈中每个数据节点的定义 栈的类的定义 栈的push操作 栈应用之进制转换 栈的操作(push和pop) 栈的组织形式 如上图所示:栈也是有多个数据节点组成的,每个节点包含有数据域和指向下一个节点的指针域.并且每次的push.pop和判空都是操作的栈顶指针top. 栈中每个数据节点的定义 class data_node{ public: data_node() :data(0), next(NULL){}//default constructer

  • jQuery中extend函数简单用法示例

    本文实例讲述了jQuery中extend函数简单用法.分享给大家供大家参考,具体如下: var result=$.extend({},item,item1); extend给对象添加新的属性:js插件经常使用来配置参数 {}:item和item1合并后的结果 item:默认属性 item1:新增属性,如果item1和item属性重合则会覆盖item1中的属性 <span id="Test"></span> var item={"name":&

  • AngularJS中一般函数参数传递用法分析

    本文实例讲述了AngularJS中一般函数参数传递用法.分享给大家供大家参考,具体如下: 1. 模型参数 直接使用变量名,不要加引号 <!doctype html> <html ng-app="passAter"> <head> <meta charset="utf-8"/> </head> <body> <div ng-controller="passCtrl">

  • Sql Server中Substring函数的用法实例解析

    SQL 中的 substring 函数是用来抓出一个栏位资料中的其中一部分.这个函数的名称在不同的资料库中不完全一样: MySQL: SUBSTR( ), SUBSTRING( ) Oracle: SUBSTR( ) SQL Server: SUBSTRING( ) SQL 中的 substring 函数是用来截取一个栏位资料中的其中一部分. 例如,我们需要将字符串'abdcsef'中的'abd'给提取出来,则可用substring 来实现: select substring('abdcsef'

  • Jquery中map函数的用法

    很久没用map()这个函数了,由于最近看一篇react的文章,其中有谈到map()这个函数,于是就重新查了一些资料,发现map()函数可以用在不同的地方,下面小编总结具有内容分享给大家,也方便今后查找. 其实,本人一直很少用map()这个函数,因为最近看一篇React的文章,其实有谈及map()函数,于是自己也重新查了一些资料,发现map()函数也可以用在不同的地方: map()函数把每个元素通过函数传递到当前匹配集合中,生成包含返回值的新的Jquery对象 语法:.map(callback(i

  • Python中int()函数的用法浅析

    int()是Python的一个内部函数 Python系统帮助里面是这么说的 >>> help(int) Help on class int in module __builtin__: class int(object) | int(x[, base]) -> integer | | Convert a string or number to an integer, if possible. A floating point | argument will be truncated

  • JavaScript中匿名函数的用法及优缺点详解

    匿名函数可以有效的保证在页面上写入Javascript,而不会造成全局变量的污染. 这在给一个不是很熟悉的页面增加Javascript时非常有效,也很优美. 一.什么是匿名函数? 在Javascript定义一个函数一般有如下三种方式: 函数关键字(function)语句: function fnMethodName(x){alert(x);} 函数字面量(Function Literals): var fnMethodName = function(x){alert(x);} Function(

  • JS中sort函数排序用法实例分析

    本文实例讲述了JS中sort函数排序用法.分享给大家供大家参考,具体如下: 最近遇到了一个面试题目,关于排序的问题,为了完善自己的知识点,这里就写一下学习笔记 <html> <head> <TITLE>class_obj_js_class</TITLE> <script language=javaScript> //sort()方法默认是按照ASCII码大小排序,看下面两个例子 function sortDemo(){ var a, l; //

  • 简述Matlab中size()函数的用法

    size()函数用来获取矩阵的行数和列数. (1)s=size(A), 当只有一个输出参数时,返回一个行向量,该行向量的第一个元素时矩阵的行数,第二个元素是矩阵的列数. (2)[r,c]=size(A), 当有两个输出参数时,size函数将矩阵的行数返回到第一个输出变量r,将矩阵的列数返回到第二个输出变量c. (3)size(A,n)如果在size函数的输入参数中再添加一项n,并用1或2为n赋值,则 size将返回矩阵的行数或列数.其中r=size(A,1)该语句返回的时矩阵A的行数, c=si

  • C#中累加器函数Aggregate用法实例

    本文实例讲述了C#中累加器函数Aggregate用法.分享给大家供大家参考.具体如下: var shouldExclude = false; var dirName = dir.Name; foreach(var pattern in excludePatterns) { shouldExclude = shouldExclude || Regex.Match(dirName, pattern).Success; } // 使用Aggregate改写 var dirName = dir.Name

  • 对pandas中apply函数的用法详解

    最近在使用apply函数,总结一下用法. apply函数可以对DataFrame对象进行操作,既可以作用于一行或者一列的元素,也可以作用于单个元素. 例:列元素 行元素 列 行 以上这篇对pandas中apply函数的用法详解就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持我们. 您可能感兴趣的文章: 浅谈Pandas中map, applymap and apply的区别

随机推荐