题目大意:原题链接

关键是正确理解题目意思

首先:介绍一下list容器的一些操作:参考链接

list<int> c1;

c1.unique();              去重。

c1.reverse();             反转链表。

c1.insert(pos,num);   在pos位置插入元素num。

c1.insert(pos,n,num);在pos位置插入n个元素num。

c1.assign(n,num);     将n个num拷贝赋值给链表c。

c1.sort();                  将链表排序(默认升序)。

c1.swap(c2);             将c1和c2交换。

c1.remove(num);       删除链表中值为num的元素。

c1.push_back(num);  在末尾位置添加一个元素。

c1.pop_back();          删除最末尾的元素。

c1.push_front(num);  在开始位置添加一个元素。

c1.pop_front();          删除第一个元素。

c1.erase(pos);    删除pos位置的元素。

按要求模拟木块移动:有n(0<n<25)块block以及5种操作:

move a onto b:在将a搬到b所在的那堆积木上之前,先把a和b上方的积木放回原來的位置

move a over b:在将a搬到b所在的那堆积木上之前,先把a上方的积木放回原來的位罝

pile a onto b  : 在将a搬到b所在的那堆积木上之前,先将b上方的积木放回原来的位置

pile a over b  : 将包括a本身和a上方的积木一起搬到到b所在的那堆上方(以上三种也都包括a)

quit:结束命令,以上四个操作中,若a和b在同一堆中,则不进行任何操作。

注意:

1.当一个位置的初始箱子移走之后,因为这里没有箱子,其他箱子也不会移到这个位置。

2.数组p[id]=jd表示编号为id的木块放在编号为jd的木块上面

3.void Move(int x,int y)函数中为了保证移动后保持原来的顺序(包括最下方的木块)而利用一个临时变量

#include<list>
#include<cstdio>
#include<string>
#include<iostream>
using namespace std;
list<int> temp;
list<int> lis[];
int p[]; void Recover(int x)
{
int id=p[x];
while(lis[id].back()!=x){
int t=lis[id].back();
p[t]=t;//细节
lis[t].push_back(t);
lis[id].pop_back();
}
}
void Move(int x,int y)
{
int id=p[x],jd=p[y];
while(lis[id].back()!=x){
temp.push_back(lis[id].back());
lis[id].pop_back();
}
p[x]=jd;//细节
lis[jd].push_back(lis[id].back());//正确理解题意保持原来的的顺序
lis[id].pop_back();//清理干净
while(!temp.empty()){
lis[jd].push_back(temp.back());
p[temp.back()]=jd;
temp.pop_back();
}
} int main()
{
int n,a,b;
string str1,str2;
scanf("%d",&n);
for(int i=;i<n;i++){
p[i]=i;
lis[i].push_back(i);
}
while(cin>>str1&&str1!="quit"){
cin>>a>>str2>>b;
if(str1=="move"&&str2=="onto"){
Recover(a);
Recover(b);
Move(a,b);
}
else if(str1=="move"&&str2=="over"){
Recover(a);
Move(a,b);
}
else if(str1=="pile"&&str2=="onto"){
Recover(b);
Move(a,b);
}
else if(str1=="pile"&&str2=="over")
Move(a,b);
}
for(int i=;i<n;i++){
printf("%d:",i);
while(!lis[i].empty()){
printf(" %d",lis[i].front());
lis[i].pop_front();
}
printf("\n");
}
}

PKU 1208 The Blocks Problem(模拟+list应用)的更多相关文章

  1. POJ 1208 The Blocks Problem

    The Blocks Problem Time Limit: 1000MS   Memory Limit: 10000K Total Submissions: 5397   Accepted: 231 ...

  2. uva 101 POJ 1208 The Blocks Problem 木块问题 vector模拟

    挺水的模拟题,刚开始题目看错了,poj竟然过了...无奈.uva果断wa了 搞清题目意思后改了一下,过了uva. 题目要求模拟木块移动: 有n(0<n<25)快block,有5种操作: m ...

  3. POJ 1208 The Blocks Problem --vector

    http://poj.org/problem?id=1208 晚点仔细看 https://blog.csdn.net/yxz8102/article/details/53098575 #include ...

  4. B -- POJ 1208 The Blocks Problem

    参考:https://blog.csdn.net/yxz8102/article/details/53098575 https://www.cnblogs.com/tanjuntao/p/867892 ...

  5. The Blocks Problem(vector)

    题目链接:http://poj.org/problem?id=1208 The Blocks Problem Time Limit: 1000MS   Memory Limit: 10000K Tot ...

  6. 【UVA - 101】The Blocks Problem(vector+模拟)

    The Blocks Problem Descriptions:(英语就不说了,直接上翻译吧) 初始时从左到右有n个木块,编号为0~n-1,要求实现下列四种操作: move a onto b: 把a和 ...

  7. UVa 101 The Blocks Problem Vector基本操作

    UVa 101 The Blocks Problem 一道纯模拟题 The Problem The problem is to parse a series of commands that inst ...

  8. 木块问题(The Blocks Problem,Uva 101)

    不定长数组:vector vector就是一个不定长数组.不仅如此,它把一些常用操作“封装”在了vector类型内部. 例如,若a是一个vector,可以用a.size( )读取它的大小,a.resi ...

  9. UVa 101 - The Blocks Problem(积木问题,指令操作)

    题目来源:https://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&category=3&pa ...

随机推荐

  1. PyQt的Layout的比例化分块。

    一. QGridLayout: // 列比 第0列与第1列之比为 1:2 layout2p1 -> setColumnStretch(0, 1); layout2p1 -> setColu ...

  2. ubuntu 16.04安装 navicat

    原文地址:http://www.cnblogs.com/wbJson/p/5655537.html 下载地址:http://download2.navicat.com/download/navicat ...

  3. powershell---高级函数的介绍

    https://guhuajun.wordpress.com/2009/05/11/windows-powershell-v2-介绍(5)-高级函数(上)/ https://guhuajun.word ...

  4. 适配iOS 8备忘录 开始启动(持续更新。。。1130)

    本文转载至 http://www.cocoachina.com/bbs/read.php?tid=229352 PS:大家都说看到那么多图标很头痛,我来给大家解决这个问题:直接下载我的这个包Image ...

  5. 【BZOJ1486】[HNOI2009]最小圈 分数规划

    [BZOJ1486][HNOI2009]最小圈 Description Input Output Sample Input 4 5 1 2 5 2 3 5 3 1 5 2 4 3 4 1 3 Samp ...

  6. 知问前端——html+jq+jq_ui+mySql+ajax

    **************************************************************************************************** ...

  7. Hibernate的多对多映射关系

    example: 老师(teacher)和学生(Student)就是一个多对多的关系吧?老师可以有多个学生,学生也可以由多个老师,那在Hibernate中多对多是怎样实现的呢?? 在Hibernate ...

  8. Struts2的OGNL的用法

    1 <%@ page language="java" import="java.util.*" pageEncoding="ISO-8859-1 ...

  9. hdu4686 简单的矩阵快速幂求前n项和

    HDU4686 题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=4686 题意:题目说的很清楚了,英语不好的猜也该猜懂了,就是求一个表达式的前n项和,矩阵 ...

  10. 【Python数据挖掘】决策树、随机森林、Bootsing、

    决策树的定义 决策树(decision tree)是一个树结构(可以是二叉树或非二叉树).其每个非叶节点表示一个特征属性上的测试,每个分支代表这个特征属性在某个值域上的输出,而每个叶节点存放一个类别. ...