//*****-*-----vector***///////

常用操作封装,a.size();可以读取大小

              a.resize();可以改变大小;

              a.push_back();可以向尾部添加元素;

    因为是个模板类

    声明:

            vector<int>a;vector<int>是一个类似于int a[];的整数数组;

            vector<int>b;

            vector<string>是类似于string a[]的字符串数组;

    vector 看上去像一个一等公民,因为他们可以直接赋值,还可以作为函数的参数或者返回值,

           而无须像数组那样另外用一个变量来指定元素个数。

   

    /*****------UVA101的木块问题------********/

   

    从左到右有n个木块,编号为0~n-1,要模拟四种操作;

   

    move a onto b:把a和b上方的木块全部归为,然后把a摞在b上面。

    move a over b:把a上面的全部归位,然后把a放下b所在木块堆的顶部。

    pile a onto b:把b上方的木块全部归位,然后把a及上面的木块整体摞在b上面。

    pile a over b:把a及上面的木块整体摞在b所在木块的顶部。

#include<cstdio>

#include<string>

#include<vector>

#include<iostream>

using namespace std;

const int maxn=30;

int n;

vector<int> pile[maxn];

//找木块a所在的pile和height,以引用的形式返回调用者;

void find_block(int a,int &p. int &n)

{

    for(int p=0;p<n;p++)

    {

        for(int h=0;h<pile;p++)

        {

            if(pile[p][h]==a)

                return;

        }

    }

}



//*****--------把p堆上的所有元素都放回原处***-----*/

void clear_above(int p,int h)

{

    for(int i=h+1;i<pile[p].size();i++)

    {

        int b=pile[p][i];

        pile[b].push_back(b);

    }

    pile[p].resize(h+1);//保留0~h的元素

}

//把p堆高度为h及其上方的木块整体放到p2堆的顶部;

void pile_onto(int p,int p2,int h)

{

    for(int i=h;i<pile[p].size();i++)

    {

        pile[p2].push_back(pile[p][i]);

    }

    pile[p].resize(h);

}

和数组相比的话:

 【优点】

 安全,不会不小心越界

 可以利用标准库的很多功能,包括现成的成员函数和一些泛化算法

 【缺点】

 使用迭代器必须要小心



 VECTOR 在频繁的插入和删除 效率比较低

  特别如果是大型的对象会增加很多的析构和拷贝

  小型的对象和内置数据类型VECTOR 效率还是比较高的

  所以如果是小型的对象和内置数据类型 可以用VECTOR 比LIST效率高

  除非你有非常频繁的删除插入



             

             

 

vector刘汝佳算法入门学习笔记的更多相关文章

  1. 刘汝佳 算法竞赛-入门经典 第二部分 算法篇 第五章 1(String)

    第一题:401 - Palindromes UVA : http://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8 ...

  2. 刘汝佳 算法竞赛-入门经典 第二部分 算法篇 第六章 1(Lists)

    127 - "Accordian" Patience 题目大意:一个人一张张发牌,如果这张牌与这张牌前面的一张或者前面的第三张(后面称之为一位置和三位置)的点数或花式相同,则将这张 ...

  3. 刘汝佳 算法竞赛-入门经典 第二部分 算法篇 第五章 3(Sorting/Searching)

    第一题:340 - Master-Mind Hints UVA:http://uva.onlinejudge.org/index.php?option=com_onlinejudge&Item ...

  4. 刘汝佳 算法竞赛-入门经典 第二部分 算法篇 第五章 2(Big Number)

    这里的高精度都是要去掉前导0的, 第一题:424 - Integer Inquiry UVA:http://uva.onlinejudge.org/index.php?option=com_onlin ...

  5. 刘汝佳 算法竞赛-入门经典 第二部分 算法篇 第六章 2(Binary Trees)

    112 - Tree Summing 题目大意:给出一个数,再给一颗树,每个头节点的子树被包含在头节点之后的括号里,寻找是否有从头节点到叶子的和与给出的数相等,如果有则输出yes,没有输出no! 解题 ...

  6. poj 1363 Rails (【栈的应用】 刘汝佳的写法 *学习)

    Rails Time Limit: 1000MS   Memory Limit: 10000K Total Submissions: 25964   Accepted: 10199 Descripti ...

  7. Scala入门学习笔记三--数组使用

    前言 本篇主要讲Scala的Array.BufferArray.List,更多教程请参考:Scala教程 本篇知识点概括 若长度固定则使用Array,若长度可能有 变化则使用ArrayBuffer 提 ...

  8. OpenCV入门学习笔记

    OpenCV入门学习笔记 参照OpenCV中文论坛相关文档(http://www.opencv.org.cn/) 一.简介 OpenCV(Open Source Computer Vision),开源 ...

  9. ACM题目推荐(刘汝佳书上出现的一些题目)[非原创]

    原地址:http://blog.csdn.net/hncqp/article/details/1758337 推荐一些题目,希望对参与ICPC竞赛的同学有所帮助. POJ上一些题目在http://16 ...

随机推荐

  1. [Unit Testing] Test async function with Jasmine

    Most of time, when we want to test function call inside a promise, we can do: it('Should be async', ...

  2. SolidEdge 如何由装配图快速生成爆炸视图

    建立图纸精灵,组态中选择explode(没有下一步可选了)   点击完成即可绘制爆炸图

  3. Effective C++ 条款17 以独立语句将newed对象置入智能指针

      对于函数: int priority(); void processWidget(std::tr1::  shared_ptr<Widget> pw,int priority); 调用 ...

  4. unity常见问题之20题

    1:天空盒有接缝怎么解决? 答:在贴图导入设置里设置Wrap Mode为"Clamp". 2: DDS格式怎么不显示? 答:Unity不支持DDS格式,Unity会将除DDS外的其 ...

  5. struts(转)

    配置文件的优先级 在struts2中一些配置(比如常量)可以同时在struts-default.xml(只读性),strtus-plguin.xml(只读性),struts.xml,struts.pr ...

  6. Beijing Bus

    Search: http://bjgj.aibang.com:8899 https://github.com/sp-chenyang/bus https://github.com/leavind/Co ...

  7. java类加载机制的代码实例

    package typeinfo; import java.util.Random; class Initable { static final int staticFinal = 47 ; stat ...

  8. linux输入子系统(6)-input子系统介绍及结构图

    注:本系列转自: http://www.ourunix.org/post/290.html input子系统介绍         输入设备(如按键,键盘,触摸屏,鼠标,蜂鸣器等)是典型的字符设备,其一 ...

  9. Spring中的IOC容器(学习笔记)

    如何将Bean配置到Spring的Bean容器中 通过xml配置文件: Bean实现类来自第三方类库:如“DataSource”等      需要命名空间配置如:context,aop,mvc等   ...

  10. 求a + aa + aaa + aaaa + aaaaa ...的值,例如:1 + 11 + 111,2 + 22 + 222 + 2222 + 22222

    #include <stdio.h> unsigned superposition(unsigned m, unsigned n); int main() { printf("1 ...