PAT (Basic Level) Practice 部分汇总(C++版)

2023-11-04

1003 我要通过!测试点2没通过(已解决)

有没有好心人帮我看看为什么错了一个
在这里插入图片描述
题目:

“答案正确”是自动判题系统给出的最令人欢喜的回复。本题属于 PAT 的“答案正确”大派送 —— 只要读入的字符串满足下列条件,系统就输出“答案正确”,否则输出“答案错误”。

得到“答案正确”的条件是:

字符串中必须仅有 P、 A、 T这三种字符,不可以包含其它字符;
任意形如 xPATx 的字符串都可以获得“答案正确”,其中 x 或者是空字符串,或者是仅由字母 A 组成的字符串;
如果 aPbTc 是正确的,那么 aPbATca 也是正确的,其中 a、 b、 c 均或者是空字符串,或者是仅由字母 A 组成的字符串。
现在就请你为 PAT 写一个自动裁判程序,判定哪些字符串是可以获得“答案正确”的。

输入格式:
每个测试输入包含 1 个测试用例。第 1 行给出一个正整数 n (≤10),是需要检测的字符串个数。接下来每个字符串占一行,字符串长度不超过 100,且不包含空格。

输出格式:
每个字符串的检测结果占一行,如果该字符串可以获得“答案正确”,则输出 YES,否则输出 NO。

#include<iostream>
using namespace std;
int check(string s)
{
    int num[3]={0,0,0};
    int index=0;
    for(int i=0;i<s.size();i++)
    {
        if(s[i]=='A'){num[index]++;continue;}
        else if(s[i]=='P'&&index==0)
        {
            index++;continue;
        }
        else if(s[i]=='T'&&index==1)
        {
            index++;continue;
        }
        else{
            cout<<"NO"<<endl;
            return 0;
        }
    }
    if(num[2]==num[1]*num[0]&&num[1]!=0){
        cout<<"YES"<<endl;
        return 0;
    }
    else{
        cout<<"NO"<<endl;
        return 0;
    }
}

int main()
{
    int n;
    cin>>n;
    for(int i=0;i<n;i++)
    {
        string s;
        cin>>s;
        check(s);
    }
    return 0;
}


测试点2是PA,再加一个检查index能不能到3就可以了。

1008 数组元素循环右移问题

如果测试点2,3不通过就考虑一下m>n的情况

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

int main()
{
    int n,m;
    cin>>n>>m;
    m=m%n;
    vector<int> num(n);
    for(int i=0;i<n;i++)
    {
        cin>>num[i];
    }
    for(int i=n-m;i<n;i++)
    {
        cout<<num[i]<<" ";
    }
    for(int i=0;i<n-m-1;i++)
    {
        cout<<num[i]<<" ";
    }
    cout<<num[n-m-1];
    return 0;
}

1009 说反话

用到两个小技巧:

  1. 用do while判断是否输入完
  2. 用栈来反向输出
#include<iostream>
#include<stack>
#include<string>
using namespace std;

int main()
{
    stack<string> str;
    string s;
    do{
        cin>>s;
        str.push(s);
    }while(getchar()!='\n');
    while(str.size()>1)
    {
        cout<<str.top()<<" ";
        str.pop();
    }
    cout<<str.top();
    return 0;
}
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

PAT (Basic Level) Practice 部分汇总(C++版) 的相关文章

随机推荐

  • Vue修改数据页面不更新的问题解决

    第一种场景 动态给对象新增属性或者删除属性是不会触发视图刷新的 Vue识别不到 第二种场景 通过数组下标修改数组中的元素或者手动修改数组的长度 Vue识别不到 解决方法1 静默刷新 使用v if的特性 在修改值之后将元素销毁 然后在修改后的
  • Java GUI编程(Swing)(窗口 面板 弹窗)

    目录 一 窗口 面板 Swing 重点 重点 重点 如果想给窗口进行背景颜色 必须要给窗口JFrame实例化 否则其他没有颜色 例如 jframe setBackground Color BLUE 背景无颜色 Container conta
  • Minio 部署

    minio 官网 https www minio org cn 部署文档 https www minio org cn docs minio container operations install deploy manage deploy
  • SQL中JOIN和UNION

    join 是两张表做交连后里面条件相同的部分记录 可以是不同字段 产生一个记录集 union是产生的两个记录集 字段要一样的 并在一起 成为一个新的记录集 JOIN用于按照ON条件联接两个表 主要有四种 INNER JOIN 内部联接两个表
  • Vision Transformer(ViT)

    1 前言 本文讲解Transformer模型在计算机视觉领域图片分类问题上的应用 Vision Transformer ViT 本人全部文章请参见 博客文章导航目录 本文归属于 计算机视觉系列 2 Vision Transformer Vi
  • Linux rootfs(根文件系统讲解)

    rootfs 其实就是 针对特定的操作系统的架构 一种实现的形式 具体表现为 特定的目录 就理解为windows的文文件夹 目录之间的关系 即组织架构 以及特定的各种文件 boot 系统启动的相关文件 如内核 initrd 以及grup b
  • proxy_set_header Host $host;

    server listen 80 server name www yuetai net cn 核心代码 rewrite https server name 1 permanent location proxy set header X Re
  • HC-02蓝牙串口模块的配置和使用

    HC 02蓝牙串口模块是基于蓝牙2 0并兼容BLE的双模蓝牙数传模块 带底板的蓝牙模块如下图 模块可以作为从机与HC 05或HC 06的主机设备通信 也可以和手机通信 模块在上电未连接蓝牙的时候LED快闪指示 这时可使用串口助手AT指令配置
  • 远场(far-field)语音识别的主流技术有哪些

    转自 https www zhihu com question 48537863 远场 far field 语音识别的主流技术有哪些 以amazon echo为首的一批智能硬件正在崛起 这些硬件实现语音识别功能时面临的一个挑战性的问题就是如
  • apache 2.4 + php 5.5 配置

    网上流传的大都是 Apache 2 2 和 php 5 4的配置 还那么多人转来转去 害苦了多少入门的新手 以下内容适合apache 2 4 php 5 5 mysql或者mariadb的安装配置不说了 从apachelounge下载Apa
  • PCB如何添加3D模型

    我们在布线完PCB后 可以通过按下键盘的数字 3 来查看自己的板子3D模式下的样子 然后我们可以将一些元器件的3D模型添加上去 看一下板子焊接上元器件是什么样子 所以我们可以手动将3D元器件添加上去也可以在选择元器件的封装时候添加其3D封装
  • 监督学习-贝叶斯分类器

    贝叶斯分类器 1 原理 先验概率 某个事件B发生的概率P B 条件 后验 概率 事件B在另一事件A已发生条件下的发生概率P B A 联合概率 两个事件共同发生的概率P A B P B A 2 多个离散属性的条件概率 样本x是n维的特征向量
  • iOS APP打包上传到APPstore的最新步骤

    一 前言 作为一名iOS开发者 把辛辛苦苦开发出来的App上传到App Store是件必要的事 但是很多人还是不知道该怎么上传到App Store上 下面就来详细讲解一下具体流程步骤 二 准备 一个已付费的开发者账号 可分为 账号类型分为个
  • VS2019查找库函数文件夹的方法

    我的路径 C Program Files x86 Windows Kits 10 Include 10 0 19041 0 ucrt 方法 1 新建一个项目 打上所想找到的库函数 2 右击 gt 转到文档 3 右击选项卡 gt 打开文件夹
  • PyTorch预训练和微调:以VGG16为例

    文章目录 预训练和微调代码 测试结果 参考来源 预训练和微调代码 数据集 CIFAR10 CIFAR 10数据集由10类32x32的彩色图片组成 一共包含60000张图片 每一类包含6000图片 其中50000张图片作为训练集 10000张
  • 记一次APP脱壳重打包过程

    小伙伴分享了一个开车软件 但是有播放次数限制 对此小伙伴放言要制裁它 无奈APP加固了 咳咳 本着学 wei 习 le 研 fu 究 li 的态度 尝试着脱壳并重打包 为证清白 伸出双手 上操作 右键直接解压APK 查看特征是360加固 使
  • 成为一个优秀的测试工程师需要具备哪些知识和经验?

    软件测试每个阶段有不同的要掌握的技术和经验 先按照薪资范围划分下 月薪 5 9K 零基础入门 学会功能测试能够找到工作 15 25K 测试在职能搞定性能测试和自动化测试 25K 搞定测试开发 在一线大厂工作 每一个阶段的侧重也不同 入门到找
  • 开关电源与线性电源

    一 线性电源 1 三极管有截止区 放大区 饱和区 而当三极管工作在放大区的时候由它的输出特性曲线可以发现它可以近似看成一个线性输出 因此可以利用三极管来构建一个线性电源 2 另外一种方式当输入一个交流信号时候 我们可以先通过一个整流桥转换为
  • [806]Jenkins安装部署

    Jenkins文档 https www jenkins io zh doc jenkins依赖java环境 下载jenkins 在windows系统上搭建jenkins持续集成有两种方法 1 war文件 可以用tomcat或者java命令直
  • PAT (Basic Level) Practice 部分汇总(C++版)

    目录 1003 我要通过 测试点2没通过 已解决 1008 数组元素循环右移问题 1009 说反话 1003 我要通过 测试点2没通过 已解决 有没有好心人帮我看看为什么错了一个 题目 答案正确 是自动判题系统给出的最令人欢喜的回复 本题属