POJ 1208 The Blocks Problem
| Time Limit: 1000MS | Memory Limit: 10000K | |
| Total Submissions: 5397 | Accepted: 2312 |
Description
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:

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
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
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:
Source
#include <cstdio>
#include <vector>
using namespace std; int n, a, b;
char op1[5], op2[5];
vector<int> v[30]; //找到所在积木的位置及高度
void findBlock(int a, int& p, int& h)
{
for(p = 0; p < n; ++p)
for(h = 0; h < (int)v[p].size(); ++h)
if(v[p][h] == a)
return;
} //清除位置p上高度h以上的积木
void clearAbove(int p, int h)
{
for(size_t i = h+1; i < v[p].size(); ++i){
int tmp = v[p][i];
v[tmp].push_back(tmp);
}
v[p].resize(h+1);
} //移动位置p上高度h及以上的积木到位置p2上
void moveBlock(int p, int h, int p2)
{
for(size_t i = h; i < v[p].size(); ++i)
v[p2].push_back(v[p][i]);
v[p].resize(h);
} int main()
{
scanf("%d", &n);
for(int i = 0; i < n; ++i)
v[i].push_back(i);
while(scanf("%s", op1), op1[0] != 'q'){
scanf("%d%s%d", &a, op2, &b);
int pa, pb, ha, hb;
findBlock(a, pa, ha);
findBlock(b, pb, hb);
if(pa == pb)
continue;
if(op1[0] == 'm')
clearAbove(pa, ha);
if(op2[1] == 'n')
clearAbove(pb, hb);
moveBlock(pa, ha, pb);
}
for(int i = 0; i < n; ++i){
printf("%d:", i);
for(size_t j = 0; j < v[i].size(); ++j)
printf(" %d", v[i][j]);
printf("\n");
}
return 0;
}
POJ 1208 The Blocks Problem的更多相关文章
- POJ 1208 The Blocks Problem --vector
http://poj.org/problem?id=1208 晚点仔细看 https://blog.csdn.net/yxz8102/article/details/53098575 #include ...
- uva 101 POJ 1208 The Blocks Problem 木块问题 vector模拟
挺水的模拟题,刚开始题目看错了,poj竟然过了...无奈.uva果断wa了 搞清题目意思后改了一下,过了uva. 题目要求模拟木块移动: 有n(0<n<25)快block,有5种操作: m ...
- B -- POJ 1208 The Blocks Problem
参考:https://blog.csdn.net/yxz8102/article/details/53098575 https://www.cnblogs.com/tanjuntao/p/867892 ...
- PKU 1208 The Blocks Problem(模拟+list应用)
题目大意:原题链接 关键是正确理解题目意思 首先:介绍一下list容器的一些操作:参考链接 list<int> c1; c1.unique(); 去重. c1.r ...
- The Blocks Problem(vector)
题目链接:http://poj.org/problem?id=1208 The Blocks Problem Time Limit: 1000MS Memory Limit: 10000K Tot ...
- UVa 101 The Blocks Problem Vector基本操作
UVa 101 The Blocks Problem 一道纯模拟题 The Problem The problem is to parse a series of commands that inst ...
- UVa 101 - The Blocks Problem(积木问题,指令操作)
题目来源:https://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&category=3&pa ...
- POJ.3468 A Simple Problem with Integers(线段树 区间更新 区间查询)
POJ.3468 A Simple Problem with Integers(线段树 区间更新 区间查询) 题意分析 注意一下懒惰标记,数据部分和更新时的数字都要是long long ,别的没什么大 ...
- POJ 1208 模拟
2017-08-28 15:07:16 writer:pprp 好开心,这道题本来在集训的时候做了很长很长时间,但是还是没有做出来,但是这次的话,只花了两个小时就做出来了 好开心,这次采用的是仔细分析 ...
随机推荐
- php数组函数序列之array_unshift() 在数组开头插入一个或多个元素
array_unshift() 函数在数组开头插入一个或多个元素.被加上的元素作为一个整体添加,这些元素在数组中的顺序和在参数中的顺序一样 array_unshift()定义和用法 array_uns ...
- 2013 ACM-ICPC长沙赛区全国邀请赛——Bottles Arrangement
这题当时竟然没看啊…… 找规律:求和m+m+m-1+m-1+……前n项 ;}
- VBScript 函数
Date/Time 函数 Conversion 函数 Format 函数 Math 函数 Array 函数 String 函数 其他函数 Date/Time 函数 函数 描述 CDate 把一个有效的 ...
- maven_Error building POM (may not be this project's POM)错误
如果maven项目在执行编译等操作时报如题错误的话,请仔细检查pom.xml,一般是由pom的语法错误导致的,例如我的项目是因为: dependencies 元素下不应该有properties元素导致 ...
- Openflow的转发与传统的转发区别和优势
来源:(SDN QQ群语录20130819) http://www.sdnap.com/sdnap-post/2411.html 山东同学-菜(Q群279796875) 21:40:21我是想问,op ...
- Java传入参数个数不确定可用(Type ... values)
/** * 可变长的参数. * 有时候,我们传入到方法的参数的个数是不固定的,为了解决这个问题,我们一般采用下面的方法: * 1. 重载,多重载几个方法,尽可能的满足参数的个数.显然这不是什么好办法. ...
- jQuery编程基础精华02(属性、表单过滤器,元素的each,表单选择器,子元素过滤器(*),追加方法,节点,样式操作)
属性.表单过滤器 属性过滤选择器: $("div[id]")选取有id属性的<div> $("div[title=test]")选取title属性为 ...
- iOS 深入理解RunLoop
RunLoop 是 iOS 和 OSX 开发中非常基础的一个概念,这篇文章将从 CFRunLoop 的源码入手,介绍 RunLoop 的概念以及底层实现原理.之后会介绍一下在 iOS 中,苹果是如何利 ...
- eclipse 中忽略jsp, xml文件中的报错信息
有的时候, 在eclipse中, jsp, xml 文件时运行的好好的, 可是就是在eclipse中报错, 虽然不影响功能, 但看起来很烦, 去掉这些错误警告的方法是: Windows-Prefere ...
- MVC5中Model层开发数据注解
ASP.NET MVC5中Model层开发,使用的数据注解有三个作用: 数据映射(把Model层的类用EntityFramework映射成对应的表) 数据验证(在服务器端和客户端验证数据的有效性) 数 ...