一、栈(stack)

1.定义:

栈是一种只能在某一端插入和删除数据的特殊线性表。他按照先进先出的原则存储数据,先进的数据被压入栈底,最后进入的数据在栈顶,需要读数据的时候从栈顶开始弹出数据(最后被压入栈的,最先弹出)。因此栈也称先进后出表。

允许进行插入删除操作的一端称为栈顶,另一端称为栈底。栈底固定,栈顶浮动。插入元素称为进栈,删除一个元素称为进栈,栈内元素为零称为空栈。

2.stack成员函数

bool empty ( ) ————>栈为空返回true,否则返回false;

void pop ( ) ————>删除栈顶元素,出栈;

void push(const TYPE&value)————> 插入新元素value,放置在栈顶进栈;TYPE:类型int,char…;

size_type size ( ) ————> 返回堆栈中元素个数;(注意注意!!!!切不可赋值给int ,很容易超过int的范围

TYPE&top()————> 查看当前栈顶元素;

Many areas of Computer Science use simple, abstract domains for both

analytical and empirical studies. For example, an early AI study of

planning and robotics (STRIPS) used a block world in which a robot arm

performed tasks involving the manipulation of blocks.

In this problem you will model a simple block world under certain

rules and constraints. Rather than determine how to achieve a

specified state, you will “program” a robotic arm to respond to a

limited set of commands.

The problem is to parse a series of commands that instruct a robot arm

in how to manipulate blocks that lie on a flat table. Initially there

are n blocks on the table (numbered from 0 to n − 1) with block bi

adjacent to block bi+1 for all 0 ≤ i < n − 1 as shown in the diagram

below:

Initial Blocks World

The valid commands for the robot arm that manipulates blocks are:

• move a onto b

where a and b are block numbers, puts block a onto block b after

returning any blocks that are stacked on top of blocks a and b to

their initial positions.

• move a over b

where a and b are block numbers, puts block a onto the top of the

stack containing block b, after returning any blocks that are stacked

on top of block a to their initial positions.

• pile a onto b

where a and b are block numbers, moves the pile of blocks consisting

of block a, and any blocks that are stacked above block a, onto block

b. All blocks on top of block b are moved to their initial positions

prior to the pile taking place. The blocks stacked above block a

retain their order when moved.

• pile a over b

where a and b are block numbers, puts the pile of blocks consisting of

block a, and any blocks that are stacked above block a, onto the top

of the stack containing block b. The blocks stacked above block a

retain their original order when moved.

• quit

terminates manipulations in the block world. Any command in which a =

b or in which a and b are in the same stack of blocks is an illegal

command. All illegal commands should be ignored and should have no

affect on the configuration of blocks.

Input

The input begins with an integer n on a line by itself representing

the number of blocks in the block world. You may assume that 0 < n <

25.

The number of blocks is followed by a sequence of block commands, one

command per line. Your program should process all commands until the

quit command is encountered. You may assume that all commands will be

of the form specified above. There will be no syntactically incorrect

commands.

Output

The output should consist of the final state of the blocks world. Each

original block position numbered i (0 ≤ i < n where n is the number of

blocks) should appear followed immediately by a colon. If there is at

least a block on it, the colon must be followed by one space, followed

by a list of blocks that appear stacked in that position with each

block number separated from other block numbers by a space. Don’t put

any trailing spaces on a line.

There should be one line of output for each block position (i.e., n

lines of output where n is the integer on the first line of input).

Sample Input

10

move 9 onto 1

move 8 over 1

move 7 over 1

move 6 over 1

pile 8 over 6

pile 8 over 5

move 2 over 1

move 4 over 9

quit

Sample Output

0: 0

1: 1 9 2 4

2:

3: 3

4:

5: 5 8 7 6

6:

7:

8:

9:

本以为这个题要用到stack,结果发现这个题Vector就能做!!!

2019/02/16 STL容器 :栈的更多相关文章

  1. 2019.02.16 spoj Query on a tree IV(链分治)

    传送门 题意简述: 捉迷藏强化版(带有边权,可以为负数) 思路:好吧这次我们不用点分树,我们用听起来更屌的链分治. 直接把树剖成若干条重链,这样保证从任意一个点跳到根节点是不会跳超过logloglog ...

  2. 2019.02.16 bzoj5466: [Noip2018]保卫王国(链分治+ddp)

    传送门 题意简述: mmm次询问,每次规定两个点必须选或者不选,求树上的带权最小覆盖. 思路: 考虑链分治+ddpddpddp 仍然是熟悉的套路,先考虑没有修改的状态和转移: 令fi,0/1f_{i, ...

  3. C++ STL 容器之栈的使用

    Stack 栈是种先进后出的容器,C++中使用STL容器Stack<T> 完美封装了栈的常用功能. 下面来个demo 学习下使用栈的使用. //引入IO流头文件 #include<i ...

  4. STL容器

    啦啦啦,今天听啦高年级学长讲的STL容器啦,发现有好多东西还是有必要记载的,毕竟学长是身经百战的,他在参加各种比赛的时候积累的经验可不是一天两天就能学来的,那个可是炒鸡有价值的啊,啊啊啊啊啊 #inc ...

  5. c++ stl容器set成员函数介绍及set集合插入,遍历等用法举例

    c++ stl集合set介绍 c++ stl集合(Set)是一种包含已排序对象的关联容器.set/multiset会根据待定的排序准则,自动将元素排序.两者不同在于前者不允许元素重复,而后者允许. 1 ...

  6. STL容器的本质

    http://blog.sina.com.cn/s/blog_4d3a41f40100eof0.html 最近在学习unordered_map里面的散列函数和相等函数怎么写.学习过程中看到了一个好帖子 ...

  7. 关于STL容器

    容器: 概念:如果把数据看做物体,容器就是放置这些物体的器物,因为其内部结构不同,数据摆放的方式不同,取用的方式也不同,我们把他们抽象成不同的模板类,使用时去实例化它 分类: 序列容器.关联容器.容器 ...

  8. STL 容器简介

    一.概述 STL 对定义的通用容器分三类:顺序性容器.关联式容器和容器适配器. 顺序性容器是一种各元素之间有顺序关系的线性表.元素在顺序容器中保存元素置入容器时的逻辑顺序,除非用删除或插入的操作改变这 ...

  9. STL 容器的概念

    STL 容器的概念 在实际的开发过程中,数据结构本身的重要性不会逊于操作于数据结构的算法的重要性,当程序中存在着对时间要求很高的部分时,数据结构的选择就显得更加重要. 经典的数据结构数量有限,但是我们 ...

随机推荐

  1. 在tap的碎片上与活动进行绑定实现点击事件(日期时间选择以及按钮跳转时间)

    主要是掌握怎样在Fragment类型的.java文件中实现对于文本框或者按钮点击事件的触发操作. 相应的出发时间都是之前的代码.主要是怎样在Fragment怎样实现相应的操作主要是对于getActiv ...

  2. 05-CSV文件读取(问题)

    1.支持.txt,.log,.json三种格式 并且也支持.csv格式文件类型----.csv在使用时会出现乱码情况 2.当时遇到问题: CSV文件.txt文本内有数据,如:user ,pwd adm ...

  3. Windows Server 2016 Storage Replication

    Storage Replication是Windows Server 2016中新增的一项功能,它是利用windows server自带的块存储复制技术 首先,我们简答粗暴的交代一下部署需求: 1.该 ...

  4. 使用 Python 查看局域网内存活主机

    1 安装 (如果误用了 pip insatll nmap的话,要先 pip uninstall nmap) pip install python-nmap Nmap 是一款用于网络发现和安全审计的网络 ...

  5. php.ini配置文件详解(基于5.2.17版本)

    [PHP] ;;;;;;;;;;;;;;;;;;;; About php.ini ;;;;;;;;;;;;;;;;;;;; ;;;;;;;;;;;;;;;;;;;; 关于php.ini文件 ;;;;; ...

  6. EL表达式 -- 比较不错

    EL表达式 EL 全名为Expression Language EL 语法很简单,它最大的特点就是使用上很方便.接下来介绍EL主要的语法结构: ${sessionScope.user.sex} 所有E ...

  7. Volatile可见性分析(一)

    JUC(java.util.concurrent) 进程和线程 进程:后台运行的程序(我们打开的一个软件,就是进程) 线程:轻量级的进程,并且一个进程包含多个线程(同在一个软件内,同时运行窗口,就是线 ...

  8. vue的组件缓存(返回页面不刷新)

    每次使用返回是页面总是会刷新 导致了一些体验上的不愉快 现在 发现vue中的一个很方便的方法还可以用来优化性能就是: keep-alive缓存组件 <router-view v-if=" ...

  9. 使用Scanner接受用户键盘输入的值

    第一步导入Scanner import java.util.*; 第二步创建Scanner对象 Scanner input = new Scanner(System.in); 第二步创建Scanner ...

  10. 【Java】Operator 运算符/操作符

    Operator 运算符/操作符 什么是操作符? 一个表示特定的数学或逻辑操作的符号 算术运算符 加 + 减 - 乘 * 除 / 取模 % 前置自运算 ++ a .--b 后置自运算 a++ .b-- ...