/*
* vectorDemo.cpp
*
* Created on: Jul 17, 2014
* Author: lichfeng
*/
#include<vector>
#include <iostream.h>
#include <algorithm>
#include"vectorDemo.H" using namespace std; void vectorDemo() {
/**************************************************************************/
/* constructors functions */
/**************************************************************************/
vector<int> first; // empty vector of ints
vector<int> second(4, 100); // four ints with value 100
vector<int> third(second.begin(), second.end()); // iterating through second
vector<int> fourth(third); // a copy of third
// the iterator constructor can also be used to construct from arrays:
int myints[] = { 16, 2, 77, 29, 8, 3, 24 };
vector<int> fifth(myints, myints + sizeof(myints) / sizeof(int)); cout << "The contents of fifth are:";
for (vector<int>::iterator it = fifth.begin(); it != fifth.end(); ++it)
cout << ' ' << *it;
cout << '\n'; /**************************************************************************/
/* iterator erase (iterator position); */
/* iterator erase (iterator first, iterator last); */
/* erase(): 在vector中移除一个元素(通过position),或者移除一个区间([first, last))内的元素*/
/* 该函数返回值是所删除的元素的下一个元素。 */
/* Note: 由于vector是以数组形式组织的,所以删除中间元素将导致vector中其他元素向前移动。这对vector */
/* 而言是低效的操作,应减少使用。但此操作对list和deque等链表组织的容器很高效. */
/**************************************************************************/
//vector<int>::iterator ii;
fifth.erase(fifth.begin() + 1);
cout << "After erase by position, the contents of fifth are:";
for (vector<int>::iterator it = fifth.begin(); it != fifth.end(); ++it)
cout << ' ' << *it;
cout << '\n'; fifth.erase(fifth.begin(), fifth.begin() + 2);
cout << "After erase by range, the contents of fifth are:";
for (vector<int>::iterator it = fifth.begin(); it != fifth.end(); ++it)
cout << ' ' << *it;
cout << '\n'; /***************************************************************************/
/* capacity(): 返回当前vector已分配的存储空间大小(按照所存元素类型),该值大于等于size() */
/* size(): 返回当前vector所实际存储的元素数目 */
/* max_size(): 该vector可以分配的最大内存空间(操作系统限制的) */
/* push_back():在vector末尾增加一个元素,将导致size数加1。当且仅当size数大于当前容量时, */
/* 引起vector内存重新分配(按内存非配器算法增加vector容量 */
/* pop_back(): 移除vector的最后一个元素,引起size减少1 */
/* begin(): 返回指向vector第一个元素的iterator */
/* end(): 返回指向vector最后一个元素的下一个元素的iterator, 不能取值。 */
/* cbegin(): 返回指向vector第一个元素的const iterator,不允许修改vector数据 */
/* cend(): 返回指向vector最后一个元素的下一个元素的const iterator, 不能取值。 */
/* at(): 返回at(position)中position的引用. */
/* front(): 返回vector第一個元素的引用. */
/* back(): 返回vector中最后一个元素的引用. */
/* clear(): 移除vector中所有的元素,将导致vector size为0.(capacity非强制变化). */
/**************************************************************************/
vector<int> vIntTest;
cout << "0:The size is " << vIntTest.size() << endl;
cout << "0:The capacity is " << vIntTest.capacity() << endl;
cout << "0:The max capacity is " << vIntTest.max_size() << endl; for (int i = 0; i < 10; i++)
vIntTest.push_back(i);
cout << "1:The size is " << vIntTest.size() << endl;
cout << "1:The capacity is " << vIntTest.capacity() << endl; vIntTest.pop_back();
cout << "2:The size is " << vIntTest.size() << endl;
cout << "2:The capacity is " << vIntTest.capacity() << endl; vIntTest.insert(vIntTest.end(), 10, 100);
cout << "3:The size is " << vIntTest.size() << endl;
cout << "3:The capacity is " << vIntTest.capacity() << endl; vIntTest.at(0) = 100;
vIntTest.at(1) = 200;
cout << "After set by at():";
for (vector<int>::iterator it = fifth.begin(); it != fifth.end(); ++it)
cout << ' ' << *it;
cout << '\n'; vIntTest.back() = 1000;
cout << "After set by back():";
for (vector<int>::iterator it = fifth.begin(); it != fifth.end(); ++it)
cout << ' ' << *it;
cout << '\n';
/***************************************************************************/
/* rbegin(): 返回指向vector最后一个元素的迭代器,对翻转迭代器加操作将导致其向前移动. */
/* empty(): 判斷vector是否為空并返回,空返回true,非空返回false */
/* resize(): 調整容器的size以包含n個元素,移除多餘的元素或增大內存空間 */
/* reserve(): 要求vector capacity至少包含n個元素,如果n大于當前capacity,vector容量將增加 */
/***************************************************************************/
vector<int> reserveVec(5);
vector<int>::reverse_iterator ri; int i=0;
for(ri=reserveVec.rbegin(); ri!=reserveVec.rend(); ri++)
{
*ri = ++i;
} cout<<"reserveVec contains: ";
for(vector<int>::iterator it= reserveVec.begin(); it != reserveVec.end(); it++)
cout<<"*it ";
cout<<endl; /***************************************************************************/
/* data(): 返回vector首元素的内部C类型指针,通过该指针完成所有的操作. */
/* empty(): 判斷vector是否為空并返回,空返回true,非空返回false */
/* resize(): 調整容器的size以包含n個元素,移除多餘的元素或增大內存空間 */
/* reserve(): 要求vector capacity至少包含n個元素,如果n大于當前capacity,vector容量將增加 */
/***************************************************************************/ //data()
/*vector<int> myvector(5); int* p = myvector.data(); *p = 10;
++p;
*p = 20;
p[2] = 100; cout << "myvector contains:";
for (unsigned i = 0; i < myvector.size(); ++i)
cout << ' ' << myvector[i];
cout << '\n';*/ // reserve()
vector<int>::size_type sz; vector<int> foo;
sz = foo.capacity();
std::cout << "making foo grow:\n";
for (int i = 0; i < 100; ++i) {
foo.push_back(i);
if (sz != foo.capacity()) {
sz = foo.capacity();
cout << "capacity changed: " << sz << '\n';
}
} vector<int> bar;
sz = bar.capacity();
bar.reserve(100); // this is the only difference with foo above
cout << "making bar grow:\n";
for (int i = 0; i < 100; ++i) {
bar.push_back(i);
if (sz != bar.capacity()) {
sz = bar.capacity();
cout << "capacity changed: " << sz << '\n';
}
} //resize
vector<int> myvector1; // set some initial content:
for (int i = 1; i < 10; i++)
myvector1.push_back(i); myvector1.resize(5);
myvector1.resize(8, 100);
myvector1.resize(12); cout << "myvector contains:";
for (int i = 0; i < myvector1.size(); i++)
cout << ' ' << myvector1[i];
cout << '\n';
//myvector contains: 1 2 3 4 5 100 100 100 0 0 0 0 }

Vector Demo的更多相关文章

  1. [javaSE] 集合框架(ArrayList,LinkedList,Vector)

    ArrayList特点:底层使用数组数据结构,查询速度快(使用脚标查),插入删除慢(索引要改变) LinkedList特点:底层使用链表数据结构,查询慢(需要一个一个去问),插入删除快 Vector特 ...

  2. 集合框架-Vector集合

    1 package cn.itcast.p1.vector.demo; 2 3 import java.util.Enumeration; 4 import java.util.Iterator; 5 ...

  3. C# 使用SIMD向量类型加速浮点数组求和运算(1):使用Vector4、Vector<T>

    作者: 目录 一.缘由 二.使用向量类型 2.1 基本算法 2.2 使用大小固定的向量(如 Vector4) 2.2.1 介绍 2.2.2 用Vector4编写浮点数组求和函数 2.3 使用大小与硬件 ...

  4. Scalaz(47)- scalaz-stream: 深入了解-Source

    scalaz-stream库的主要设计目标是实现函数式的I/O编程(functional I/O).这样用户就能使用功能单一的基础I/O函数组合成为功能完整的I/O程序.还有一个目标就是保证资源的安全 ...

  5. boost之bind

    bind1st bind2nd在stl里面有具体的实现,只是只能绑定两个参数. boost里面的bind使用bind(Fun f,A1 a1,A2,a2...)产生一个对象,这个对象可以有占位符,可以 ...

  6. PHP 类名::class含义

    自 PHP 5.5 起,关键词 class 也可用于类名的解析. 使用 ClassName::class 可以获取一个字符串,包含了类 ClassName 的完全限定名称.这对使用了命名空间的类尤其有 ...

  7. juc多线程编程学习

    JUC是java.util.concurrent的缩写,java.util.concurrent是在并发编程中使用的工具类. 在以前的解决并发问题,一般是通过Synchronize关键字,现在可以通过 ...

  8. Applying vector median filter on RGB image based on matlab

    前言: 最近想看看矢量中值滤波(Vector median filter, VMF)在GRB图像上的滤波效果,意外的是找了一大圈却发现网上没有现成的code,所以通过matab亲自实现了一个,需要学习 ...

  9. 关于QImage提取单色通道方法(vector)

    转载请标明处: 作者:微微苏荷 本文地址:关于QImage提取单色通道方法(vector) 近日,用QT和mxnet结合做一个图像识别的demo.遇到需要把图片从QImage转为vector单色分离的 ...

随机推荐

  1. PowerDotNet平台化软件架构设计与实现系列(04):服务治理平台

    系统和系统之间,少不了数据的互联互通.随着微服务的流行,一个系统内的不同应用进行互联互通也是常态. PowerDotNet的服务治理平台发源于早期的个人项目Power.Apix.这个项目借鉴了工作过的 ...

  2. [hdu6761]Minimun Index

    $lyndon\ word$(以下简写为Lw):对于一个字符串s,其为Lw当且仅当其的最小后缀为自身 性质:若$u<v$为LW,那么$uv$也为Lw(反证法即可证) $lyndon$分解:将一个 ...

  3. Redis基本数据类型底层数据结构

    Redis数据类型底层数据结构 Redis目前基本的数据类型有String.List.Set.ZSet.Hash五种,首先Redis是C语言开发的,所以底层就是用C语言封装数据结构或者C语言本身提供的 ...

  4. CF1511E Colorings and Dominoes

    考虑计数拆开贡献. 因为在一个方案中一个格子最多只会贡献一次,那么不妨反过来求这个格子贡献了多少次. 然后发现,行列独立,那么我们单独计算红蓝色,即可. 一个偶数块贡献当且仅当前面也是偶数块. 然后显 ...

  5. 洛谷 P5280 - [ZJOI2019]线段树(线段树+dp,神仙题)

    题面传送门 神仙 ZJOI,不会做啊不会做/kk Sooke:"这八成是考场上最可做的题",由此可见 ZJOI 之毒瘤. 首先有一个非常显然的转化,就是题目中的"将线段树 ...

  6. IOI 2020 国家集训队作业

    \(\checkmark\) 试题一 完成情况 试题二 完成情况 试题三 完成情况 cf549E cf674G arc103_f \(\checkmark\) cf594E agc034_f agc0 ...

  7. Markdown 目录

    Markdown 目录 1. TOC TOC 全称为 Table of Content,自动列出全部标题. 用法: [toc] 在 Markdown 中,自动生成目录非常简单,只需要在恰当的位置添加 ...

  8. 【R】ggplot2的facet_warp/grid如何实现超过两类水平的分面?

    之前最多只做过两类单水平的分面,即两两组合的面板图.如果某类超过两个水平呢? 一类的分面:facet_wrap(~ align) 两类的分面(x轴和y轴):facet_grid(align ~ gen ...

  9. Linux内网时钟同步问题(ntp和chrony)

    我们都知道时钟同步可以使用外网服务器,在内网内不能连接外网的时候也需要时钟同步,那怎么进行呢? 选择内网的一台稳定的服务器作为时钟源,然后让其他机器都来同步这台机器即可. 注:其实ntp服务和chro ...

  10. EPOLL原理详解(图文并茂)

    文章核心思想是: 要清晰明白EPOLL为什么性能好. 本文会从网卡接收数据的流程讲起,串联起CPU中断.操作系统进程调度等知识:再一步步分析阻塞接收数据.select到epoll的进化过程:最后探究e ...