L1-044 稳赢 (15 分)
大家应该都会玩“锤子剪刀布”的游戏:两人同时给出手势,胜负规则如图所示:
现要求你编写一个稳赢不输的程序,根据对方的出招,给出对应的赢招。但是!为了不让对方输得太惨,你需要每隔K次就让一个平局。
输入格式:
输入首先在第一行给出正整数K(≤10),即平局间隔的次数。随后每行给出对方的一次出招:ChuiZi代表“锤子”、JianDao代表“剪刀”、Bu代表“布”。End代表输入结束,这一行不要作为出招处理。
输出格式:
对每一个输入的出招,按要求输出稳赢或平局的招式。每招占一行。
输入样例:
2
ChuiZi
JianDao
Bu
JianDao
Bu
ChuiZi
ChuiZi
End
输出样例:
Bu
ChuiZi
Bu
ChuiZi
JianDao
ChuiZi
Bu
#include <iostream>
#include <string>
using namespace std;
int main() {
int k;
cin >> k;
int i=0;
string pose;
while (true) {
cin >> pose;
if (pose == "End")
break;
if (i % k == 0 && i != 0) {//一定要加i!=0
cout << pose << endl;
i = -1;//重置i也很关键
}
else {
if (pose == "ChuiZi")
cout << "Bu" << endl;
if (pose == "Bu")
cout << "JianDao" << endl;
if (pose == "JianDao")
cout << "ChuiZi" << endl;
}
i += 1;
}
return 0;
}
这题非常经典,因为这道题目我之前学python的时候做过,当时的解法是正负索引,但是C++没有正负索引,而且最大的问题是要间隔几轮平局。
一开始,我怎么调试都调试不出来隔两轮输出平局。我一开始陷入了调整i(计数器)的初始值可以解决问题的误区,一直调整但没有突破。后来只能把计数器重置让每隔相应的轮数平局的次数一直,居然解决了问题。测试的数据也能正常输出答案,但是提交的时候只有4分。人直接傻掉。
后来仔细发现,我把结束循环的语句放到了后面,导致在第二轮的时候输入End是不会结束循环的,也就是说我逻辑上出了问题。
结束语句放最开头就能解决问题