//*****-*-----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. 初探STL之算法

    算法 STL算法部分主要由头文件<algorithm>,<numeric>,<functional>组成.要使用 STL中的算法函数必须包括头文件<algor ...

  2. react jsx 数组变量的写法

    1.通过 map 方法 var students = ["张三然","李慧思","赵思然","孙力气","王萌 ...

  3. Yii自动生成项目

      我喜欢尝试新鲜的东西.以前一直用gii生成工具,前几天突然发现用shell的方法,感觉很不错.特此总结一下yii的几个命令.   gii的工具页面: - Controller Generator ...

  4. 鼠标滚轮实现图片的缩放-------Day79

    今天是7月的最后一天了,不得不说,我定下的七月份剩余几天的计划是完不成了.一则工作确实紧了些,再则没能处理好生活.工作和学习的节奏.这才是人生最大的课题吧.只是也还好.至少自己还在坚持着.事实上真的越 ...

  5. Win8下怎样安装Win7 or Win7下怎样安装win8?

    预计非常多人可能会用U盘安装工具去去做双系统的安装(Win8下安装Win7, Win7下安装Win8).可是在安装过程中你 会发现一个问题:win7下安装win8,提示你mbr硬盘格式不能安装win8 ...

  6. 你的以太网速度足够快吗?四种更快的速度正在路上&#183;&#183;&#183;&#183;&#183;&#183;

    以太网的未来将远远超越下一个最快速度:为无处不在的网络协议绘制路径的网络project师们正在寻找新版本号来服务于各种应用程序. 在上周六的以太网联盟(一个行业组织,用于促进IEEE以太网标准)会议上 ...

  7. RFC外部断点在在SAP退出后会失效

    rfc外部断点系统退出后会删除吗?  不会删除Rfc外部断点在在SAP退出后标识还在, 但是断点会失效! 附 断点消息: ABAP 中的断点分为静态和动态两种.一. 静态断点(Static Break ...

  8. 组合模式(遍历树,file基表示文件也表示文件夹)

    组合模式多个对象形成树形结构以表示“整体--部分”的结构层次.组合模式对单个对象(即叶子对象)和组合对象(即容器对象)的使用具有一致性. 组合模式又可以称为“合成模式“ 或 ”整体-部分模式”,属于对 ...

  9. MYSQL进阶学习笔记九:MySQL事务的应用!(视频序号:进阶_21-22)

    知识点十:MySQL 事务的应用 (21-22) 为什么要引入事务: 为什么要引入事务这个技术呢?现在的很多软件都是多用户,多程序,多线程的.对同一表可能同时有很多人在用,为保持数据的一致性,所以提出 ...

  10. JavaScript SHA-1

    1. [文件] webtoolkit.sha1.js ~ 4KB     /****  Secure Hash Algorithm (SHA1)*  http://www.huiyi8.com/css ...