poj 1575 Easier Done Than Said?

本文探讨了一段用于评估程序代码质量的C++代码片段,重点在于通过一系列逻辑判断来确定代码中字母字符的使用情况,从而评估其是否符合特定的可接受标准。文章详细解释了代码中实现的三种不同条件判断逻辑,并最终决定代码是否符合要求。

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

#include <iostream>
#include <string>
using namespace std;

int main()
{
    int i, len;
    string str;
    bool flag1, flag2, flag3, flag4;
    while (cin >> str)
    {
          if (str == "end")  break;
          len = str.length();
          flag1 = flag2 = flag3 = flag4 = false;
          //第一种情况的判断 
          for (i = 0; i < len; i++)
          {
              if (str[i] == 'a' || str[i] == 'e' || str[i] == 'o' || str[i] == 'i' || str[i] == 'u')
              {
                 flag1 = true;
                 break;
              }
          }
          //第二种情况的判断 
          for (i = 0; i < len - 2; i++)
          {
              if (str[i] == 'a' || str[i] == 'e' || str[i] == 'o' || str[i] == 'i' || str[i] == 'u')
              {
                  if (str[i+1] == 'a' || str[i+1] == 'e' || str[i+1] == 'o' || str[i+1] == 'i' || str[i+1] == 'u')
                  {
                       if (str[i+2] == 'a' || str[i+2] == 'e' || str[i+2] == 'o' || str[i+2] == 'i' || str[i+2] == 'u')
                       {
                            flag2 = true;
                            break;
                       }
                  }
              }
          }
          for (i = 0; i < len - 2; i++)
          {
              if (str[i] != 'a' && str[i] != 'e' && str[i] != 'o' && str[i] != 'i' && str[i] != 'u')
              {
                  if (str[i+1] != 'a' && str[i+1] != 'e' && str[i+1] != 'o' && str[i+1] != 'i' && str[i+1] != 'u')
                  {
                      if (str[i+2] != 'a' && str[i+2] != 'e' && str[i+2] != 'o' && str[i+2] != 'i' && str[i+2] != 'u')
                      {
                          flag3 = true;
                          break;
                      }
                  }
              }
          }
          //第三种情况的判断 
          for (i = 0; i < len - 1; i++)
          {
              if (str[i] == str[i+1] && str[i] != 'e' && str[i] != 'o')
              {
                  flag4 = true;
                  break;
              }
          }
          
          if (flag1 && !flag2 && !flag3 && !flag4)
             cout << "<" << str << ">" << " is acceptable." << endl;
          else
             cout << "<" << str << ">" << " is not acceptable." << endl;
    }
    
    system("pause");
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值