//*****-*-----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. Tomcat载入两次问题

    前提介绍: 1.某个应用Dragon放置路径:/opt/apache-tomcat-7.0.47/webapps/Dragon 2.Tomcat的server.xml部分配置信息例如以下:    &l ...

  2. Android设置系统开机自己主动永不休眠

    android4.2系统增永不休眠同一时候隐藏休眠选项 1. android\frameworks\base\packages\SettingsProvider\res\values\defaults ...

  3. HDU 2669 Romantic(扩展欧几里德)

    题目链接:pid=2669">http://acm.hdu.edu.cn/showproblem.php?pid=2669 Problem Description The Sky is ...

  4. saltstack安装配置(syndic)

    syndic是saltstack用来做集群部署的,一般结构如图: syndic是一个特殊的minion,syndic类继承于minion类,syndic可以看作一个代理,只做数据传递. CentOS上 ...

  5. BEGINNING SHAREPOINT&#174; 2013 DEVELOPMENT 第8章节--配送SP2013Apps 应用程序生命周期

    BEGINNING SHAREPOINT® 2013 DEVELOPMENT 第8章节--配送SP2013Apps 应用程序生命周期         你在商店拥有一个应用程序后.跟踪不论什么人们碰到的 ...

  6. 用NHibernate处理带属性的多对多关系

    1.引言 老谭在面试开发者的时候,为了考察他们的数据库开发能力,经常祭出我的法宝,就是大学数据库教程中讲到的一个模式:学生选课.这个模式是这种: 在这个模式中,学生(Student)和课程(Cours ...

  7. DataFactory 5.6注册码

    一.DataFactory 5.6注册码 数据工厂5.6注册码如下,希望能帮助需求之人 AuthKey: 0-87093-23830-05141-17507 SiteMsg: FREELAND EVO ...

  8. Appium,IOS 模拟器,Java工程搭建

    首先进入sample code Test App 有TestApp.xcodeproj文件的工程目录下 下编译出TestApp.app文件 1.新建 java 工程 2.import需要的包 新建cl ...

  9. Ajax的简单实现

    Ajax的实现需要服务器端和客户端配合来实现 下面看服务器端的代码,也就是用php编写的一个后台脚本文件 <?php //设置页面内容,编码格式是utf8 header("Conten ...

  10. 在C++中使用Libmd5计算字符串或文件的MD5值

    CppMD5Demo.cpp #include <iostream> #include <fstream> #include <chrono> #include & ...