hdoj 1039

原创 2014年06月08日 14:16:06
#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 很重要

相关文章推荐

[HDOJ 1039] Easier Done Than Said? (基础,字符串) .

先贴上在VC6.0上运行无误但在HDOJ后台海量测试数据通之下无法通过的代码,以便以后分析错误原因。 #include using namespace std; bool isVowel(ch...
  • ajioy
  • ajioy
  • 2012年03月01日 12:49
  • 541

hdoj1039简单题、字符串处理

#include//代码有些地方还不够简洁 #include #include using namespace std; bool is_vowel(char ch){ if(ch ...

HDOJ/HDU 1039 Easier Done Than Said?(字符串处理~)

Problem Description Password security is a tricky thing. Users prefer simple passwords that are eas...

ACM--元辅音--HDOJ 1039--Easier Done Than Said?--字符串

HDOJ题目地址:传送门 Easier Done Than Said? Time Limit: 2000/1000 MS (Java/Others)    Memory Lim...

HDOJ1039 - Easier Done Than Said?

题目: Easier Done Than Said?

驱动精灵2014.4.3 1039

  • 2014年04月04日 15:13
  • 32.37MB
  • 下载

d3dx1039文件名

  • 2013年07月19日 08:38
  • 160KB
  • 下载

1039. 到底买不买(20) PAT

1039. 到底买不买(20) 时间限制 100 ms 内存限制 65536 kB 代码长度限制 8000 B 判...

POJ1039-Pipe

  • 2011年07月31日 23:13
  • 11KB
  • 下载

判断直线相交思维好题 (poj1039)

Pipe Time Limit: 1000MS Memory Limit: 10000K Total Submissions: 10951 Accepted: 3405 Description Th...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:hdoj 1039
举报原因:
原因补充:

(最多只允许输入30个字)