HDU1022 Train Problem I
2013-03-16 11:35
369 查看
题目大意:水题一枚,但是自己很水,所以模拟了蛮久.囧.栈模拟.
开了三个栈oo1,oo2,oo3.
oo2保存要求火车离开的顺序
oo3模拟火车进站的顺序
oo1是辅助栈,为了方便提取进站的头一列车.
学数据结构的时候没好好写写伪代码,所以模拟的思路一开始一塌糊涂.后来认认真真的写一遍伪代码,思路清晰多了:
(1)如果oo3栈不为空,并且栈顶元素和oo2栈顶元素相等的话,那么两个栈都开始弹栈,直到不相等为止
(2)如果oo3栈不为空,并且oo3栈顶元素和oo2栈顶元素不相等的话,并且辅助栈oo1已经为空(说明火车已经全部进站了)
那么宣布提供的进站顺序不合理,直接标志失败跳出
(3)如果三个栈都为空了的话,那么标志成功跳出
(4)剩下的就是oo3栈顶元素和oo2栈顶元素不相等的,并且辅助栈还没空,说明还有火车可以安排进站,所以oo1进行弹栈,oo3进栈.
在oo3栈进出栈的时候,记录其活动情况最后再输出弹栈入栈顺序即可
AC program:
开了三个栈oo1,oo2,oo3.
oo2保存要求火车离开的顺序
oo3模拟火车进站的顺序
oo1是辅助栈,为了方便提取进站的头一列车.
学数据结构的时候没好好写写伪代码,所以模拟的思路一开始一塌糊涂.后来认认真真的写一遍伪代码,思路清晰多了:
(1)如果oo3栈不为空,并且栈顶元素和oo2栈顶元素相等的话,那么两个栈都开始弹栈,直到不相等为止
(2)如果oo3栈不为空,并且oo3栈顶元素和oo2栈顶元素不相等的话,并且辅助栈oo1已经为空(说明火车已经全部进站了)
那么宣布提供的进站顺序不合理,直接标志失败跳出
(3)如果三个栈都为空了的话,那么标志成功跳出
(4)剩下的就是oo3栈顶元素和oo2栈顶元素不相等的,并且辅助栈还没空,说明还有火车可以安排进站,所以oo1进行弹栈,oo3进栈.
在oo3栈进出栈的时候,记录其活动情况最后再输出弹栈入栈顺序即可
AC program:
#include<iostream> #include<stdio.h> #include<string.h> #include<stack> using namespace std; int n; char o1[11],o2[11]; int main() { while(~scanf("%d%s%s",&n,o1,o2)) { int s[20],k=0; stack<int>oo1,oo2,oo3; int len1=strlen(o1); int len2=strlen(o2); for(int i=len1-1;i>=0;i--) { oo1.push(o1[i]-'0'); } for(int i=len2-1;i>=0;i--) { oo2.push(o2[i]-'0'); } int tmp=oo1.top(); oo1.pop(); oo3.push(tmp); s[k++]=1; bool flag; while(1)//oo1是辅助栈,oo3和oo2是工作栈 { while(!oo3.empty()&&oo3.top()==oo2.top()) { oo3.pop(); s[k++]=2; oo2.pop(); } if(!oo3.empty()&&oo3.top()!=oo2.top()&&oo1.empty()) { flag=false; break; } else if(oo1.empty()&&oo2.empty()&&oo3.empty()) { flag=true; break; } else { tmp=oo1.top(); oo1.pop(); oo3.push(tmp); s[k++]=1; } } if(flag) { printf("Yes.\n"); for(int i=0;i<k;i++) { if(s[i]==1) printf("in\n"); else printf("out\n"); } printf("FINISH\n"); } else { printf("No.\n"); printf("FINISH\n"); } } //system("pause"); }
相关文章推荐
- HDU 1022 Train Problem I(判断出栈序列是否可行)
- [ACM] hdu 1022 Train Problem I(栈的使用)
- hdu 1022 Train Problem I(栈的应用+STL)
- HDU 【1022】Train Problem I
- HDU 1022 Train Problem I
- HDU 1022 Train Problem I
- HDU 1022 Train Problem I
- hdu 1022 Train Problem I
- hdu 1022 Train Problem I(模拟+栈)
- hdu 1022 Train Problem I(栈的应用。。。)
- hdu 1022 Train Problem I
- hdu-1022-Train Problem I
- hdu1022 Train Problem I
- HDU 1022 Train Problem I (STL 栈模拟)
- HDU 1022 Train Problem I
- hdu-1022-train problem I-----nyoj-150
- HDOJ/HDU 1022 Train Problem I(模拟栈)
- HDU 1022 ( Train Problem I )
- HDU 1022 Train Problem I 栈
- HDU 1022 Train Problem I