hdu 1022

10 篇文章 0 订阅
8 篇文章 0 订阅

栈学的不是很好,发现现在又不会了,拿这个经典题目来练练手~~

这里要注意的就是,i和j的细节控制。


#include <iostream>
#include <stack>
#include <cstring>
using namespace std;

char a[1010],b[1010];
int p[1010];     //0进,1出; 
 
int main()
{
  int n;
  while(cin>>n>>a>>b)
  {
     int i(0),j(0),k(0);
	 stack <char >s;
	 memset(p,0,sizeof(p));
	 while(i<=n&&j<n)
	  {
 	    if(s.empty()||s.top()!=b[j])
		 {
 		    s.push(a[i++]);			 
			p[k++]=0; 	
 		 } 	
 		
	    if(s.top()==b[j])
		{
		  s.pop();
		  j++;	
		  p[k++]=1;
		}	  	   
     }	

   if(s.empty())
    { 
     cout<<"Yes."<<endl;
      for( i=0;i<k;i++)
        {
          if(!p[i])
		    cout<<"in"<<endl;
		  else cout<<"out"<<endl;  	
        }  
    } 
    
   else cout<<"No."<<endl;
   cout<<"FINISH"<<endl;  
  
  }	
	return 0;
}



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值