博客
关于我
【PAT乙级】1003 我要通过!
阅读量:190 次
发布时间:2019-02-28

本文共 1941 字,大约阅读时间需要 6 分钟。

为了解决这个问题,我们需要编写一个自动裁判程序,判断给定的字符串是否满足特定的条件,从而输出“答案正确”或“答案错误”。

方法思路

  • 输入处理:读取输入的字符串数量和每个字符串。
  • 字符检查:确保字符串只包含P、A、T三种字符。
  • 统计字符:统计字符串中P、A、T各自的数量,并检查是否存在至少一个P和一个T。
  • 结构检查:根据题目条件,检查字符串的结构是否符合要求。具体来说,P前面的A的数量乘以P和T之间的A的数量必须等于T后面的A的数量,并且P和T之间必须至少有一个A。
  • 解决代码

    #include 
    #include
    #include
    using namespace std;int main() { int t; cin >> t; for (int i = 0; i < t; ++i) { string s; cin >> s; bool valid = true; // 检查是否只包含P、A、T for (char c : s) { if (c != 'P' && c != 'A' && c != 'T') { valid = false; break; } } if (!valid) { cout << "NO" << endl; continue; } // 统计P、A、T的数量 int P = 0, A = 0, T = 0; int aqnum = 0, aznum = 0, ahnum = 0; // 遍历字符串 for (int j = 0; j < s.size(); ++j) { if (s[j] == 'P') { ++P; } else if (s[j] == 'A') { ++A; } else if (s[j] == 'T') { ++T; } } if (P == 0 || T == 0) { cout << "NO" << endl; continue; } // 统计各个部分的A的数量 int left = 0; int mid = 0; int right = 0; for (int j = 0; j < s.size(); ++j) { if (s[j] == 'A') { if (j < P) { left++; } else if (j > P && j < T) { mid++; } else if (j > T) { right++; } } } // 检查条件 if (aznum > 0 && aqnum * aznum == ahnum) { cout << "YES" << endl; } else { cout << "NO" << endl; } }}

    代码解释

  • 输入处理:读取字符串数量t,然后逐个读取每个字符串s
  • 字符检查:遍历字符串,检查是否只包含P、A、T三种字符。如果有其他字符,标记为无效并输出“NO”。
  • 统计字符:统计字符串中P、A、T的数量。如果P或T的数量为0,直接输出“NO”。
  • 结构检查:统计P前面的A的数量(left),P和T之间的A的数量(mid),以及T后面的A的数量(right)。然后检查是否满足条件,即left * mid == rightmid > 0。满足条件则输出“YES”,否则输出“NO”。
  • 转载地址:http://nqoi.baihongyu.com/

    你可能感兴趣的文章
    NOIp模拟赛二十九
    查看>>
    Vue3+element plus+sortablejs实现table列表拖拽
    查看>>
    Nokia5233手机和我装的几个symbian V5手机软件
    查看>>
    non linear processor
    查看>>
    Non-final field ‘code‘ in enum StateEnum‘
    查看>>
    none 和 host 网络的适用场景 - 每天5分钟玩转 Docker 容器技术(31)
    查看>>
    None还可以是函数定义可选参数的一个默认值,设置成默认值时实参在调用该函数时可以不输入与None绑定的元素...
    查看>>
    NoNodeAvailableException None of the configured nodes are available异常
    查看>>
    Vue.js 学习总结(16)—— 为什么 :deep、/deep/、>>> 样式能穿透到子组件
    查看>>
    nopcommerce商城系统--文档整理
    查看>>
    NOPI读取Excel
    查看>>
    NoSQL&MongoDB
    查看>>
    NoSQL介绍
    查看>>
    NoSQL数据库概述
    查看>>
    Notadd —— 基于 nest.js 的微服务开发框架
    查看>>
    NOTE:rfc5766-turn-server
    查看>>
    Notepad ++ 安装与配置教程(非常详细)从零基础入门到精通,看完这一篇就够了
    查看>>
    Notepad++在线和离线安装JSON格式化插件
    查看>>
    notepad++最详情汇总
    查看>>
    notepad++正则表达式替换字符串详解
    查看>>