前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Train Problem I HDU 1022

Train Problem I HDU 1022

作者头像
用户2965768
发布2018-08-30 17:14:06
2410
发布2018-08-30 17:14:06
举报
文章被收录于专栏:wym

队列入门

#include <iostream>

#include <queue> #include <cstring> #include <string> using namespace std; int book[200],in[200],out[200]; string ans[200]; int main() { int n,t; int flag=1; deque<int> q; while(cin>>n) {   t=0;  flag=1; memset(book,0,sizeof(book));  while(!q.empty())q.pop_back(); getchar(); for(int i=1;i<=n;i++) { char ch;  scanf("%c",&ch); in[i]=ch-'0'; } getchar(); for(int i=1;i<=n;i++) { char ch;  scanf("%c",&ch); out[i]=ch-'0'; } //for(int i=1;i<=n;i++)   //cout<<in[i]<<" "<<out[i]<<endl; for(int i=1;i<=n;i++)    { if(book[out[i]]&&q.back()==out[i]) {  q.pop_back();  ans[t++]="out";  continue; }else if(book[out[i]]) {      printf("No.\nFINISH\n");      flag=0;   break;        }        int j;       while(!book[out[i]])            {  for( j=1;j<=n;j++)                if(!book[in[j]])                    break; book[in[j]]=1; q.push_back(in[j]); ans[t++]="in"; } ans[t++]="out"; q.pop_back(); }   if(flag)  { printf("Yes.\n"); for(int i=0;i<t;i++)                    cout<<ans[i]<<"\n";                    printf("FINISH\n"); }  } return 0; }

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2018年05月04日,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档