标签:lse case int 间隔 ima 规则 amp ase hit
大家应该都会玩“锤子剪刀布”的游戏:两人同时给出手势,胜负规则如图所示:
现要求你编写一个稳赢不输的程序,根据对方的出招,给出对应的赢招。但是!为了不让对方输得太惨,你需要每隔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 revert(string str) { if (str == "Bu") return 1; if (str == "ChuiZi") return 2; if (str == "JianDao") return 3; if (str == "End") return 0; } int win(int key) { switch (key) { case 1:return 3; break; case 2:return 1; break; case 3:return 2; break; default:return -1; } } void print(int winkey) { switch (winkey) { case 1:cout << "Bu" << endl; break; case 2:cout << "ChuiZi" << endl; break; case 3:cout << "JianDao" << endl; break; default:break; } } int main() { int k , cnt = 0; string str; cin >> k; while (cin >> str) { int key = revert(str); if (key == 0) break; else { cnt++; if (!(cnt%(k+1))) { print(key); } else { int winkey = win(key); print(winkey); } } } return 0; }
标签:lse case int 间隔 ima 规则 amp ase hit
原文地址:https://www.cnblogs.com/Frances-CY-FKYM/p/10293620.html