【題目敘述】https://zerojudge.tw/ShowProblem?problemid=c297
【解題想法】依題意「模擬」棒球球員的跑壘與得分,當到達指定出局人數時,輸出得分。

#include <iostream>
#include <map>
#include <queue>
using namespace std;
map<int, queue<string> > mp;
int main(){
int a, target;
string s;
for (int i=0; i<9; i++){
cin >> a;
queue <string> q;
for (int j=0; j<a; j++){
cin >> s;
q.push(s);
}
mp[i] = q;
}
cin >> target;
int out = 0, num = -1, score = 0;
int b1 = 0, b2 = 0, b3 = 0, b4 = 0;
while (1){
int times = 0; //跑壘數
num = (num + 1) % 9; //打者號碼
string hit = mp[num].front();
mp[num].pop();
if (hit == "SO" || hit == "GO" || hit == "FO"){
out += 1;
if (out == target) break;
if (out % 3 == 0){
b1 = b2 = b3 = b4 = 0;
}
} else if (hit == "HR"){
times = 4;
} else {
times = hit[0] - '0';
}
//跑壘
for (int i=1; i<=times; i++){
b4 = b3;
b3 = b2;
b2 = b1;
if (i == 1) b1 = 1;
else b1 = 0;
if (b4 == 1) {
score++;
}
}
}
cout << score << '\n';
return 0;
}
Python code
while True:
try:
dic = {}
for i in range(9):
lst = list(map(str, input().split()))
dic[i] = lst[1:]
target = int(input())
out = 0
num = -1
score = 0
b1 = 0
b2 = 0
b3 = 0
b4 = 0
while True:
times = 0
num = (num+1) % 9
hit = dic[num].pop(0)
if hit == 'SO' or hit == 'GO' or hit == 'FO':
out += 1
if out == target:
break
if out % 3 == 0:
b1 = 0
b2 = 0
b3 = 0
b4 = 0
elif hit == 'HR':
times = 4
else:
times = int(hit[0])
b4 = 1
for j in range(times):
b1, b2, b3, b4 = b2, b3, b4, b1
if b4 == 1:
score += 1
b4 = 0
print(score)
except:
break