hdoj 1039

#include <iostream>
#include<stdio.h>
#include<string.h>
using namespace std;
#define MAX 30
char password[MAX];

int isVowel(char c)
{
    if(c=='a'||c=='e'||c=='i'||c=='o'||c=='u')
    {
        return 1;
    }
    return 0;
}

int main()
{
    //freopen("1.txt","r",stdin);
    while(scanf("%s",password))
    {
        if(strcmp(password,"end")==0)
            return 0;

        //rule 1,zhishao yige a e i o u
        int i;
        int containOneVowel=0;
        for(i=0;i<strlen(password);i++)
        {
            if(isVowel(password[i]))
            {
                containOneVowel=1;
                break;
            }
        }


        int sameLetter=0;
        //如果符合条件一,包含一个原因字母
        if(containOneVowel)
        {
            for(i=0;i+1<strlen(password);i++)
            {
                if(password[i]==password[i+1])
                {
                    if(password[i]!='e'&&password[i]!='o')
                    {
                        sameLetter=1;
                        break;
                    }
                }
            }
        }

        int threeLetter=0;
        //如果符合条件3,不包含两个相同的字母
        if(!sameLetter)
        {
            for(i=0;i+2<strlen(password);i++)
            {
                if(isVowel(password[i])==isVowel(password[i+1])
                   &&isVowel(password[i+2])==isVowel(password[i+1]))
                {
                    threeLetter=1;
                    break;
                }
            }
        }



        if(containOneVowel&&!sameLetter&&!threeLetter)
        {
            printf("<%s> is acceptable.\n",password);
        }else{
            printf("<%s> is not acceptable.\n",password);
        }
    }
    return 0;
}

It cannot contain two consecutive occurrences of the same letter, except for 'ee' or 'oo'.

后面的except for 很重要

阅读更多
个人分类: acm
想对作者说点什么? 我来说一句

杭电OJ使用说明书 HDOJ使用说明书

2010年09月26日 1.81MB 下载

HDOJ题目分类 HDOJ题目分类

2010年04月02日 80KB 下载

没有更多推荐了,返回首页

加入CSDN,享受更精准的内容推荐,与500万程序员共同成长!
关闭
关闭