STL 容器和迭代器连载6_顺序容器的操作3

2019独角兽企业重金招聘Python工程师标准>>> hot3.png

/*- ==========================================================
*     文件名  :STL_con_ite_6.cpp
*     开发人员:袁培荣
*     当前版本:1.0.0.2595
*     创建时间:2012-05-24
*     修改时间:2012-05-24
*     功能说明:STL 容器和迭代器连载6_顺序容器的操作3
*     版权说明:版权所有 袁培荣 YuanPeirong 
*     编译环境:Windows 7(x64) SP1 简体中文专业版
*     编译器:  Visual Studio 2010 SP1(中文旗舰版)MinGW 20120426 GNU GCC 4.6.2Visual C++ 6.0 SP6(中文企业版)
- ==========================================================*/#include <iostream>
#include <vector>
#include <list>
#include <deque>
#include <string>using std::cout;
using std::endl;
using std::vector;
using std::list;
using std::deque;
using std::string;int main(int argc, char* argv[])
{//下面来介绍删除容器内元素的相关操作//先定义一个容器,并添加101个元素。vector<int> v1;for(int i=0; i!=101; i++) //C++程序员习惯于用i!=101,而不是i<101v1.push_back(i);cout<<"在所有删除操作前v1.size()="<<v1.size()<<endl;//第一种方法://erase(p) :删除迭代器p所指向的元素//返回指向被删除元素的下一位置的迭代器。//注意:p必须真实地指向实际存在的元素。cout<<"第一种方法:"<<endl;cout<<"删除前v1的第96个元素值是(方法1输出):"<<*(v1.begin()+95)<<endl;cout<<"删除前v1的第96个元素值是(方法2输出):"<<v1[95]<<endl;//我们把第96个元素删除vector<int>::iterator iter1=v1.erase(v1.begin()+95);//验证:cout<<"删除后v1.size()="<<v1.size()<<endl;cout<<"删除后v1的第96个元素值是(方法1输出):"<<*iter1<<endl;cout<<"删除后v1的第96个元素值是(方法2输出):"<<v1[95]<<endl;//第二种方法://erase(b,e) :删除迭代器b,e所指向的元素形成的左闭合区间//返回指向被删除的最后一个元素的下一位置的迭代器。cout<<"第二种方法:"<<endl;cout<<"删除前v1的第81个元素值是:"<<*(v1.begin()+80)<<endl;cout<<"删除前v1的第82个元素值是:"<<*(v1.begin()+81)<<endl;cout<<"删除前v1的第83个元素值是:"<<*(v1.begin()+82)<<endl;//我们把第81,82,83三个元素删除iter1=v1.erase(v1.begin()+80, v1.begin()+83);//验证:cout<<"删除后v1.size()="<<v1.size()<<endl;cout<<"删除后v1的第81个元素值是(方法1输出):"<<*iter1<<endl;cout<<"删除后v1的第81个元素值是(方法2输出):"<<*(v1.begin()+80)<<endl;cout<<"删除后v1的第82个元素值是:"<<*(v1.begin()+81)<<endl;cout<<"删除后v1的第83个元素值是:"<<*(v1.begin()+82)<<endl;//第三种方法://pop_back() 删除容器的最后一个元素,返回void类型cout<<"第三种方法:"<<endl;cout<<"删除前v1的最后一个元素值是:"<<*(v1.end()-1)<<endl;if(v1.size()!=0)    //防止容器为空时,删除操作引发错误v1.pop_back();//验证:cout<<"删除后v1.size()="<<v1.size()<<endl;cout<<"删除后v1的最后一个元素值是:"<<*(v1.end()-1)<<endl;//第四种方法://pop_front() 删除容器的第一个元素,返回void类型//值得注意的是,这种方法只能用于list和deque容器list<int> l1(3,0);*l1.begin()=0;      //为便于区分元素,将各修改成不相同//下面指出修改list容器的元素时的两种错误//l1[1]=1;           //list容器不支持l1[0]这样的下标访问(下面会讲)//*(l1.begin()+2)=2; //list容器的迭代器不能与数值相加(复习一下前面)list<int>::iterator iter2=l1.begin();iter2++;             //迭代器的++操作是对所有容器都支持的*(iter2)=1;iter2++;*(iter2)=2;cout<<"第四种方法:"<<endl;cout<<"删除前l1.size()="<<l1.size()<<endl;cout<<"删除前l1的第一个元素值是:"<<*l1.begin()<<endl;if(!l1.empty())     //防止容器为空时,删除操作引发错误l1.pop_front(); //empty()用来判断容器是否为空,下面会讲//验证:cout<<"删除后l1.size()="<<l1.size()<<endl;cout<<"删除后l1的第一个元素值是:"<<*l1.begin()<<endl;//虽然第四种方法pop_front(t)只支持list和deque容器//但我们用第一种方法的一个特例就能和做到第二种方法同样的效果://例如:cout<<"用第一种方法的特例实现第四种方法:"<<endl;cout<<"删除前v1.size()="<<v1.size()<<endl;cout<<"删除前v1的第一个元素值是:"<<*v1.begin()<<endl;v1.erase(v1.begin());//验证:cout<<"删除后v1.size()="<<v1.size()<<endl;cout<<"删除后v1的第一个元素值是:"<<*v1.begin()<<endl;//这样,我们可以为不支持第四种方法的容器扩展这一种方法//第五种方法://clear() 删除容器内的所有元素,返回void类型cout<<"第五种方法:"<<endl;cout<<"清空前v1.size()="<<v1.size()<<endl;cout<<"清空前l1.size()="<<l1.size()<<endl;//清空v1和l1v1.clear();l1.clear();//验证:cout<<"清空后v1.size()="<<v1.size()<<endl;cout<<"清空后l1.size()="<<l1.size()<<endl;return 0;
}//============================
//运行结果:
//============================
// 在所有删除操作前v1.size()=101
// 第一种方法:
// 删除前v1的第96个元素值是(方法1输出):95
// 删除前v1的第96个元素值是(方法2输出):95
// 删除后v1.size()=100
// 删除后v1的第96个元素值是(方法1输出):96
// 删除后v1的第96个元素值是(方法2输出):96
// 第二种方法:
// 删除前v1的第81个元素值是:80
// 删除前v1的第82个元素值是:81
// 删除前v1的第83个元素值是:82
// 删除后v1.size()=97
// 删除后v1的第81个元素值是(方法1输出):83
// 删除后v1的第81个元素值是(方法2输出):83
// 删除后v1的第82个元素值是:84
// 删除后v1的第83个元素值是:85
// 第三种方法:
// 删除前v1的最后一个元素值是:100
// 删除后v1.size()=96
// 删除后v1的最后一个元素值是:99
// 第四种方法:
// 删除前l1.size()=3
// 删除前l1的第一个元素值是:0
// 删除后l1.size()=2
// 删除后l1的第一个元素值是:1
// 用第一种方法的特例实现第四种方法:
// 删除前v1.size()=96
// 删除前v1的第一个元素值是:0
// 删除后v1.size()=95
// 删除后v1的第一个元素值是:1
// 第五种方法:
// 清空前v1.size()=95
// 清空前l1.size()=2
// 清空后v1.size()=0
// 清空后l1.size()=0
//============================

转载于:https://my.oschina.net/u/186539/blog/59452

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/463708.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

vector的内存释放

1. vector容器的内存自增长 与其他容器不同&#xff0c;其内存空间只会增长&#xff0c;不会减小。先来看看"C Primer"中怎么说&#xff1a;为了支持快速的随机访问&#xff0c;vector容器的元素以连续方式存放&#xff0c;每一个元素都紧挨着前一个元素存储。设想一…

poj 2096 , zoj 3329 , hdu 4035 —— 期望DP

题目&#xff1a;http://poj.org/problem?id2096 题目好长...意思就是每次出现 x 和 y&#xff0c;问期望几次 x 集齐 n 种&#xff0c;y 集齐 s 种&#xff1b; 所以设 f[i][j] 表示已经有几种&#xff0c;转移一下即可。 代码如下&#xff1a; #include<cstdio> #incl…

[C++]MySQL数据库操作实例

由于课程大实验需要使用c操作MySQL数据库&#xff0c;经过一番研究终于成功实现VS2008中与MySQL的连接。环境设置&#xff1a;安装完MySQL之后&#xff0c;将安装目录中的include目录下的libmysql.lib文件拷到VS2008安装目录中的VC\lib\下&#xff0c;然后在项目-选项-c/c-常规…

MapInfo开发心得——控件篇

前阵做一个项目过程中&#xff0c;需要结合MapInfo进行地方展示开发&#xff0c;积累一点点心得与大家共享以下所有基于MapXtreme 6.6MapInfo提供了足够强大的WinForm地图空间&#xff0c;可以很方便地在VS中拖拉摆放。但如此强大的控件也带来了封闭性太强的问题。现在我们都接…

89个嵌入式相关概念,你懂了几个?

嵌入式、计算机的学习&#xff0c;最基础的就是弄清一些概念。嵌入式、计算机相关的概念很多&#xff0c;这次汇总整理一些&#xff1a;1. 操作系统&#xff08;Operating System&#xff0c;OS&#xff09;&#xff1a;是管理计算机硬件与软件资源的系统软件&#xff0c;同时也…

使用VLC转码,在HTML5页面播放实时监控

首先要获取摄像机品牌的RTSP地址&#xff1a; 如大华的是rtsp://user:pwdip:port/cam/ realmonitor?channel1&subtype0 海康的是rtsp://user:pwdip:port/MPEG-4/ch1/main/av_stream Html5 <video>并不支持rtsp,所以使用vlc进行转码,将rtsp转http流,这样<video&g…

聊聊Linux中线程和进程的联系与区别!

大家好&#xff0c;推荐飞哥的一篇文章&#xff01;关于进程和线程&#xff0c;在 Linux 中是一对儿很核心的概念。但是进程和线程到底有啥联系&#xff0c;又有啥区别&#xff0c;很多人还都没有搞清楚。在网上对进程和线程的讨论中&#xff0c;很多都是聚集在这二位有啥不同。…

Docker swarm 实战-部署wordpress

Docker swarm 实战-部署wordpress 创建一个overlay的网络 docker network create -d overlay demo6imq8da3vcwvj2n499k4bwdlt docker network ls NETWORK ID NAME DRIVER SCOPE feea5ba8507b bridge bridge …

比GDB方便n倍的调试工具——CGDB

CGDB 是GDB的前端&#xff0c;在终端窗口中意图形化的形式来调试代码(基于ncurse)&#xff0c;非常方便。相对于GDB来说&#xff0c;可以很大的提高效率。这篇文章就来分享一下CGDB的最基本使用方法&#xff0c;如果是第一次听说&#xff0c;强烈建议您体验一下&#xff0c;一定…

WCF Security userName/Password

1. Transfer SecurityTransfer Security 主要包括三个方面&#xff1a; "消息完整性(Message Integrity)"、"消息机密性 (Message Confidentiality)" 和 "交互验证(Mutual Authentication)"。消息完整性必须确保消息在传输过程中没有被篡改&…

保护视力,我写的一个定时提醒的小玩意。

做程序员2年了&#xff0c;感觉视力越来越差。有时候常常工作到忘记休息。于是就想写一个能够定时提醒的小东西(公司不让从网络下载别的程序)。 功能: 1.能够每隔一段时间提醒我休息&#xff0c;做做眼保健操。 2.能够自己设定时间间隔. 运行环境&#xff1a;.ne…

WinCE程序的几种开发方法

文章允许转载,请注明出处和作者:luocq(akay_21cn_com)下面介绍的几种开发方法,还是倾向于Delphi的程序员,如果是熟练的VC程序员,当然VC是不二的选择.1、采用Delphi2007来进行WinCE .net程序开发http://spaces.msn.com/members/GordonLiWei/?partqsayear%3D2005%26amonth%3D12&…

几道Linux驱动相关面试题,你会几题?

1一、Linux基础1、任意3种网络操作的Linux命令,并说明他们的含义 1. ifconfig 命令ifconfig 用于查看和配置 Linux 系统的网络接口。 查看所有网络接口及其状态&#xff1a;ifconfig -a 。 使用 up 和 down 命令启动或停止某个接口&#xff1a;ifconfig eth0 up 和 ifconfig et…

解决Too many open files问题

转载&#xff1a;https://blog.csdn.net/zhuwinmin/article/details/72730288 当用linux做高并发服务器时&#xff0c;会遇到"Too many open files"的错误。 Linux是有文件句柄限制的&#xff08;open files&#xff09;&#xff0c;而且Linux默认不是很高&#xf…

树莓派的这十年

来源 | 新智元编辑 | 袁榭 好困刚刚过完10岁生日的树莓派&#xff0c;早已褪去了当年廉价电脑教具的外衣&#xff0c;一跃成为全球业界首屈一指的微型电脑品牌。为啥叫「Raspberry Pi」&#xff1f;从某种意义上讲&#xff0c;「树莓」这个命名方式其实很单纯&#xff0c;因为大…

layui 在springboot2.x 时,页面展示不了layui的问题

[[]]是thymeleaf的内联表达式&#xff0c;在script上加 th:inline"none" 即可 报错信息 转载于:https://www.cnblogs.com/SeaWxx/p/10287505.html

ArcGIS Flex API 中的 Flex 技术(一)--事件

作者&#xff1a;Flyingis 本文严禁用于商业目的&#xff0c;如需转载请注明作者及原文链接&#xff0c;其他疑问请联系&#xff1a;dev.vip#gmail.com 在ArcGIS Flex API中探索Flex使用是一种不错的学习方法&#xff0c;可以相互辅助理解ArcGIS Flex API和Flex&#…

C++11 bind注意事项(传引用参数的时候)

默认情况下&#xff0c;bind的那些不是占位符的参数被拷贝到bind返回的可调用对象中。 当需要把对象传到bind中的参数中时&#xff0c;需要使用ref或者cref。 例如&#xff1a;

四元數與旋轉

为什么80%的码农都做不了架构师&#xff1f;>>> 在討論「四元數」之前&#xff0c;我們來想想對三維直角座標而言&#xff0c;在物體旋轉會有何影響&#xff0c;可以擴充三維直角座標系統的旋轉為三角度系統&#xff08;Three-angle system&#xff09;&#xff0c…

玩一下数组

来源&#xff1a;嵌入式大杂烩数组是最基本的数据结构&#xff0c;关于数组的面试题也屡见不鲜&#xff0c;本文罗列了一些常见的面试题&#xff0c;仅供参考。目前有以下18道题目。数组求和求数组的最大值和最小值求数组的最大值和次大值求数组中出现次数超过一半的元素求数组…