HDU1039 Easier Done Than Said?

本文介绍了一个用于验证密码是否满足特定条件的C++程序。该程序确保密码中包含至少一个元音字母,避免三个连续的元音或辅音,并且除特殊情况外不允许两个连续相同的字符。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

题目链接:HDU1039

/*
    题目大意:验证所设密码可否接受,要求满足以下三个条件:
                                1、必须包含元音
                                2、三个连续的字母不能同时为元音或者辅音
                                3、两个连续的字母不能相同,其中"ee"."oo"除外
*/

#include <bits/stdc++.h>
using namespace std;


int main() {
    string s;
    while (cin >> s && s != "end") {
        int flag = 0;
        int p = s.size();
        for (int i = 0; i<p; i++) {
            if (s[i] == 'a' || s[i] == 'e' || s[i] == 'i' || s[i] == 'o' || s[i] == 'u')    flag = 1;
        }
        int flag1 = 0;
        for (int i = 2; i<p; i++) {
            if ((s[i] == 'a' || s[i] == 'e' || s[i] == 'i' || s[i] == 'o' || s[i] == 'u') && ((s[i-1] == 'a' || s[i-1] == 'e' || s[i-1] == 'i' || s[i-1] == 'o' || s[i-1] == 'u')) && (s[i-2] == 'a' || s[i-2] == 'e' || s[i-2] == 'i' || s[i-2] == 'o' || s[i-2] == 'u')) 
                flag1 = 1;
            else if ((s[i] != 'a' && s[i] != 'e' && s[i] != 'i' && s[i] != 'o' && s[i] != 'u') && ((s[i-1] != 'a' && s[i-1] != 'e' && s[i-1] != 'i' && s[i-1] != 'o' && s[i-1] != 'u')) && (s[i-2] != 'a' && s[i-2] != 'e' && s[i-2] != 'i' && s[i-2] != 'o' && s[i-2] != 'u'))
                flag1 = 1;
        }
        int flag2 = 0;
        for (int i = 1; i<p; i++) {
            if (s[i] == s[i-1] && (s[i] != 'e'&& s[i] != 'o')) flag2 = 1;
        }
        //cout << flag << flag1 <<flag2 <<endl;
        if (flag == 1 && flag1 == 0 && flag2 == 0)  cout << "<" << s << ">" << " is acceptable." << endl;
        else    cout << "<" << s << ">" << " is not acceptable." << endl;
        s = "";
    }
    return 0;
}


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值