题意:
从左到右有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和height void 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; }