C++ PAT 乙级 ——1003 我要通过
題目詳情
答案正確”是自動判題系統給出的最令人歡喜的回復。本題屬于 PAT 的“答案正確”大派送 —— 只要讀入的字符串滿足下列條件,系統就輸出“答案正確”,否則輸出“答案錯誤”。
得到“答案正確”的條件是:
字符串中必須僅有 P、 A、 T這三種字符,不可以包含其它字符; 任意形如 xPATx 的字符串都可以獲得“答案正確”,其中 x 或者是空字符串,或者是僅由字母 A 組成的字符串; 如果 aPbTc 是正確的,那么 aPbATca 也是正確的,其中 a、 b、 c 均或者是空字符串,或者是僅由字母 A 組成的字符串。現在就請你為 PAT 寫一個自動裁判程序,判定哪些字符串是可以獲得“答案正確”的。
輸入格式:
每個測試輸入包含 1 個測試用例。第 1 行給出一個正整數 n (<10),是需要檢測的字符串個數。接下來每個字符串占一行,字符串長度不超過 100,且不包含空格。
輸出格式:
每個字符串的檢測結果占一行,如果該字符串可以獲得“答案正確”,則輸出 YES,否則輸出 NO。
輸入樣例:
8
PAT
PAAT
AAPATAA
AAPAATAAAA
xPATx
PT
Whatever
APAAATAA
輸出樣例:
YES
YES
YES
YES
NO
NO
NO
NO
題目分析
(1)從題干中給到的“答案正確”的條件,可以得出判斷條件:
P之前的A的個數 × P和T之間的A的個數 = T之后的A的個數
并且:
P和T之間必須要有A出現
(這也是這道題目的核心,當時想著一串 if 往上懟,但看了其他博主的文章后沒想到是一個很簡單的判斷條件,/(ㄒoㄒ)/~~)
∴我們要做的就是去分別統計不同位置的A的個數,可采用下面的方法:
for (int i = 0; i < n; ++i){cin >> str;int count[3] = { 0 };int active;active = 0;for (int j = 0; j < strlen(str); ++j) //通過狀態量active來改變統計的位置{if (str[j] == 'A')count[active]++;else if (str[j] == 'P' && active == 0) //找到P之后將active加1,統計P和T之間的A的個數{active++;}else if (str[j] == 'T' && active == 1) //找到T之后再將active加1,統計T之后的A的個數{active++;}elsebreak;}………………(未完待續)(2)最后就是我們的判斷條件
………………(接上面)if ((active == 2) && (count[1]) && (count[2] == count[0] * count[1])){activate[i] = 1;} else{activate[i] = 0;}說明:activate是一個用于接收判斷狀態的量,由于最后要整體輸出,因此無法在for循環里面輸出。
Final Code
#include<iostream>using namespace std;int main() {char str[100];int n;cin >> n;int* activate = new int[n]; //由于n不是一個常量,因此無法用它直接聲明數組,需要用動態分配for (int i = 0; i < n; ++i){cin >> str;int count[3] = { 0 };int active;active = 0;for (int j = 0; j < strlen(str); ++j) //通過狀態量active來改變統計的位置{if (str[j] == 'A')count[active]++;else if (str[j] == 'P' && active == 0) //找到P之后將active加1,統計P和T之間的A的個數{active++;}else if (str[j] == 'T' && active == 1) //找到T之后再將active加1,統計T之后的A的個數{active++;}elsebreak;}if ((active == 2) && (count[1]) && (count[2] == count[0] * count[1])){activate[i] = 1;}else{activate[i] = 0;}}for (int i = 0; i < n; ++i){if (activate[i] == 1)cout << "Yes" << endl;elsecout << "No" << endl;}delete[] activate;return 0; }初學者,感謝大佬的提點
不足之處多多包涵~~(😀)
總結
以上是生活随笔為你收集整理的C++ PAT 乙级 ——1003 我要通过的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: anaconda下python中matp
- 下一篇: 没有bug队——加贝——Python 5