您的位置:首页 > 大数据 > 人工智能

Rails--POJ 1363

2010-07-16 17:37 302 查看
1、解题思路:基本数据结构stack。

2、注意事项:出栈必须先入栈、Num的越界。

3、实现方法:

#include <iostream>
using namespace std;

#define MAX 1024
int target[MAX],stack[MAX];

void Init(int n)
{
for(int i=1;i<n;i++)
cin>>target[i];
}

void Do(int n)
{
int Num=0,j=0;
stack[j]=0;
for(int i=0;i<n;i++)
{
while(1)
{
if(target[i]==stack[j])//相同,出中转站
{
j--;
break;
}
else  //不同,入中转站
{
stack[++j]=++Num;
if(Num>n)
break;
}
}
if(Num>n)
break;
}
if(j==0)
cout<<"Yes"<<endl;
else
cout<<"No"<<endl;
}

int main()
{
int n;
while(cin>>n && n)
{
while(cin>>target[0] && target[0])
{
Init(n);
Do(n);
}
cout<<endl;
}
return 0;
}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: