poj1208 The Blocks Problem,模拟,vector
来源:互联网 发布:js闭包的应用场景 编辑:程序博客网 时间:2024/05/03 11:28
题意:
从左到右有n个积木,依次编号0~n-1,要求模拟以下4种操作。
1、move a onto b
a和b都是积木的编号,先将a和b上面所有的积木都放回原处,再将a放在b上。
2、move a over b
a和b都是积木的编号,先将a上面所有的积木放回原处,再将a放在b上。(b上原有积木不动)
3、pile a onto b
a和b都是积木的编号,将a和其上面所有的积极组成的一摞整体移动到b上。在移动前要先将b上面所有的积木都放回原处。移动的一摞积木要保持原来的顺序不变。
4、pile a over b
a和b都是积木的编号,将a和其上面所有的积极组成的一摞整体移动到b所在一摞积木的最上面一个积木上。移动的一摞积木要保持原来的顺序不变。
quit
结束操作
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:
STL_vector操作:
v.front( )
返回对第一个元素的引用
v.back( )
返回对最后一个元素的引用
v.clear( )
清空vector
v.empty( )
如果为空,返回true,否则返回false
v.begin( )
返回指向第一个元素的迭代器(iterator)
v.end( )
返回指向最后一个元素的迭代器
v.pop_back( )
删除vector的最后一个元素
v.push_back(value)
将value放到vector的最后
v.size( )
返回vector中元素的个数
v.rbegin( )
返回指向末尾的逆向迭代器
v.rend( )
返回指向开头之前位置的逆向迭代器
v.swap(v1)
将v 和 v1交换
v.erase(loc)
v.erase(start,end)()中的均为iterator,删除后元素前移
删除loc所指元素,并返回下一元素迭代器
删除[start, end]元素,并返回最后被删除元素的下一个迭代器
v.insert(loc,value)
v.insert(loc,num,value)
v.insert(loc,start,end)
在loc位置插入一个value 并返回其迭代器
在loc位置插入num个value
在loc位置插入[start,end)间的元素插入后元素均后移
v.erase(unique(v.begin(),v.end()), v.end());
v.erase(remove(v.begin(), v.end(), value),
v.end());
sort(v.begin(), v.end())//要加algorithm
对vector进行排重,
删除vector中值为value的元素
对vector进行从小到大排序,可加比较函数
#include <cstdio>#include <cstring>#include <vector>#include <iostream>#include <algorithm>using namespace std;const int maxn = 25;int n;vector<int> pile[maxn];//找积木a所在的pile和heightvoid find_block(int a, int& p, int& h){ for(p=0; p<n; ++p) for(h=0; h<pile[p].size(); ++h) if(pile[p][h]==a) return ;}//把第p堆高度为h的积木上方的所有积木移回原位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); //把积木b放回原位 } pile[p].resize(h+1); //pile只应保留下标0~h的元素}//把第p堆高度为h及其上方的积木整体移动到p2堆得顶部void pile_onto(int p, int h, int p2){ for(int i=h; i<pile[p].size(); ++i) pile[p2].push_back(pile[p][i]); pile[p].resize(h);}//输出void print(){ for(int i=0; i<n; ++i){ printf("%d:", i); for(int j=0; j<pile[i].size(); ++j) printf(" %d", pile[i][j]); printf("\n"); }}int main(){ int a, b; cin>>n; string s1, s2; for(int i=0; i<n; ++i) pile[i].push_back(i); while(cin>>s1>>a>>s2>>b){ int pa, pb, ha, hb; find_block(a, pa, ha); find_block(b, pb, hb); if(pa == pb) continue; //非法操作 if(s2 =="onto") clear_above(pb, hb); if(s1 =="move") clear_above(pa, ha); pile_onto(pa, ha, pb); } print(); return 0;}
- poj1208 The Blocks Problem,模拟,vector
- poj1208 The Blocks Problem(模拟)
- POJ1208 -- The Blocks Problem
- poj1208 The Blocks Problem (栈)
- UVA101 HDU1612 POJ1208 The Blocks Problem
- 【STL】 poj1208&&UVa101 The Blocks Problem (不定长数组vector的应用)
- vector-- The Blocks Problem
- poj 1208 The Blocks Problem 模拟+vector的使用
- UVa 101 The Blocks Problem 【STL】【vector】【模拟】
- UVA101 The Blocks Problem(模拟)
- UVA - 101 The Blocks Problem vector
- UVA 101 The Blocks Problem【vector】
- UVa 101 The Blocks Problem(vector)
- UVA 101 The Blocks Problem【vector】
- uva 101 POJ 1208 The Blocks Problem 木块问题 vector模拟
- POJ 1208 The Blocks Problem [模拟]
- POJ 1208 The Blocks Problem(模拟)
- Uva 101 - The Blocks Problem//简单模拟
- hdu 5023——A Corrupt Mayor's Performance Art
- hive导入数据到hbase
- qt实现的窗口吸附屏幕边缘,动画隐藏显示的效果,类似于qq主窗口 吸附 隐藏的效果
- HDU 5038 Grade(北京网络赛G题)
- jQuery中倒计时效果
- poj1208 The Blocks Problem,模拟,vector
- HDU 3191 How Many Paths Are There
- 斐波那契数的动态规划解法
- andriod终端使用sqlite3
- DAGScheduler源码解析之Stage划分
- 代码混淆
- ASP.NET中自动生成验证码
- Android学习过程中遇到问题2
- 高性能WEB开发的性能调优(五)——小结