003:石头剪子布

总时间限制: 1000ms 内存限制: 65536kB
描述
石头剪子布,是一种猜拳游戏。起源于中国,然后传到日本、朝鲜等地,随着亚欧贸易的不断发展它传到了欧洲,到了近现代逐渐风靡世界。简单明了的规则,使得石头剪子布没有任何规则漏洞可钻,单次玩法比拼运气,多回合玩法比拼心理博弈,使得石头剪子布这个古老的游戏同时用于“意外”与“技术”两种特性,深受世界人民喜爱。

游戏规则:石头打剪刀,布包石头,剪刀剪布。

现在,需要你写一个程序来判断石头剪子布游戏的结果。
输入
输入包括N+1行:
第一行是一个整数N,表示一共进行了N次游戏。1 <= N <= 100。
接下来N行的每一行包括两个字符串,表示游戏参与者Player1,Player2的选择(石头、剪子或者是布):
S1 S2
字符串之间以空格隔开S1,S2只可能取值在{“Rock”, “Scissors”, “Paper”}(大小写敏感)中。
输出
输出包括N行,每一行对应一个胜利者(Player1或者Player2),或者游戏出现平局,则输出Tie。
样例输入
3
Rock Scissors
Paper Paper
Rock Paper
样例输出
Player1
Tie
Player2
提示
Rock是石头,Scissors是剪刀,Paper是布。

【思路】重点有两个:1.n次游戏怎么解决2.要求所有胜利者是在最后一下输出的
对于第一个问题,由于n事先未知,所以可用for循环来输入n行的字符串
对于第二个问题,同样可以用for循环来解决,可以定义一个数组result[N],记录每次的结果,最后再用一次for将n行的结果一次输出即可。
这里判断字符串的时候只取了第一个字符,以便于书写。

//石头剪刀布
#include
#include
#define N 100
char s1[10];
char s2[10];
using namespace std;
int main()
{
	int n;
	cin >> n;
	char result[N];
	for (int i = 0; i < n; i++) {
		cin >> s1>>s2;
		if ((s1[0] == 'R' && s2[0] == 'S') || (s1[0] == 'P' && s2[0] == 'R') || (s1[0] == 'S' && s2[0] == 'P'))result[i] = 0;
		else if (s1[0]==s2[0])result[i] = 1;
		else result[i] = 2;
	
	}
	for (int i = 0; i < n; i++) {
		if (result[i] == 0)cout << "Player1" << endl;
		else if (result[i] == 1)cout << "Tie" << endl;
		else cout << "Player2" << endl;
	}
	return 0;
}


你可能感兴趣的:(003:石头剪子布)