zzuoj10434: good string



10434: good string

时间限制: 1 Sec   内存限制: 128 MB
提交: 55   解决: 11
[ 提交][ 状态][ 讨论版]

题目描述

给定一个字符串,判断它是否是good string。
good string定义为:
① 字符s是good string,字符p是good string,字符y也是good string
② P和Q都是good string,则PQ是good string
③ P是good string,则(P)是good string
④ P是good string,则!P是good string
⑤ P和Q都是good string,则P|Q和P&Q是good string

输入

输入包含多组数据。每组数据为一行一个字符串,长度不超过100。

输出

对于每组数据,如果P是good string则输出"P is a good string",否则输出"P is not a good string"。

样例输入

!spy
!(s|p!y)
)sp|y

样例输出

!spy is a good string
!(s|p!y) is a good string
)sp|y is not a good string

提示

来源

spy


找不满足条件的即可

#include<cstdio>
#include<cstdlib>
#include<cstring>
using namespace std;
char str[1010];
int main()
{
	int i,j,k=1;
	while(scanf("%s",str)!=EOF){
		int len=strlen(str);
		bool sign=true;
		int l=0,r=0;
		for(i=0;i<len;++i){
			if(str[i]=='s')continue;
			else if(str[i]=='p')continue;
			else if(str[i]=='y')continue;
			else if(str[i]=='!'){
				if(i==len-1){
					sign=false;
					break;
				}
				if(str[i+1]==')'){
					sign=false;
					break;
				}
			}
			else if(str[i]==')'){
				r++;
				if(i==0){
					sign=false;
					break;
				}
				if(str[i-1]!='p'&&str[i-1]!='y'&&str[i-1]!='s'&&str[i-1]!=')'){
					sign=false;
					break;
				}
				if(r>l){
					sign=false;
					break;
				}
			}
			else if(str[i]=='|'){
				if(i==0){
					sign=false;
					break;
				}
				if(str[i+1]=='('||str[i+1]=='p'||str[i+1]=='s'||str[i+1]=='y'||str[i+1]=='!');
				else {
					sign=false;
					break;
				}
				if(str[i-1]=='p'||str[i-1]=='s'||str[i-1]=='y'||str[i-1]==')');
				else {
					sign=false;
					break;
				}
			}
			else if(str[i]=='&'){
				if(i==0){
					sign=false;
					break;
				}
				if(str[i+1]=='('||str[i+1]=='p'||str[i+1]=='s'||str[i+1]=='y'||str[i+1]=='!');
				else {
					sign=false;
					break;
				}
				if(str[i-1]=='p'||str[i-1]=='s'||str[i-1]=='y'||str[i-1]==')');
				else {
					sign=false;
					break;
				}
			}
			else if(str[i]=='('){
				l++;
				if(i==len-1){
					sign=false;
					break;
				}
				if(str[i+1]==')'){
					sign=false;
					break;
				}
			}
			else {
				sign=false;
				break;
			}
		}
		if(l!=r){
			sign=false;
		}
		if(sign){
			printf("%s is a good string\n",str);
		}
		else {
			printf("%s is not a good string\n",str);
		}
	}
	return 0;
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值