版权声明:版权所有--转载的小伙伴请告知博主并注明来源哦~ https://blog.csdn.net/u011145745/article/details/82049394
题目链接:C - 翻翻棋
来源: FZU - 2230
Problem Description
象棋翻翻棋(暗棋)中双方在4*8的格子中交战,有时候最后会只剩下帅和将。根据暗棋的规则,棋子只能上下左右移动,且相同的级别下,主动移动到地方棋子方将吃掉对方的棋子。将和帅为同一级别。然而胜负在只剩下帅和将的时候已定。
Input
第一行T,表示T组数据。
每组数据共有四行字符串,每行字符串共八个字符
’#’表示空格
’*’表示红方帅
’.’表示黑方将
此时红方先走
每组输入之间没有空行。
Output
每组数据输出一行。若为红方赢输出Red win,否则输出 Black win
Sample Input
1 ######.# #####*## ######## ########
Sample Output
Black win
Hint:本题也是考验思维的,找到规律即可。
注意:读入的时候注意scanf读入%c与cin输入的区别
示例代码如下:
#include <iostream>
#include <cstdio>
#include <cstdlib>
#include <cstring>
using namespace std;
int myabs(int x)
{
return x > 0 ? x : -x;
}
int main()
{
int T, i, j, x1, y1, x2, y2;
cin >> T; //scanf("%d", &T);
while(T--)
{
char a;
for(i = 0; i < 4; i++)
{
//getchar(); // 注意如果使用scanf输入字符,这里要加一个getchar来读入上一行的换行符
for(j = 0; j < 8; j++)
{
cin >> a;//scanf("%c", &a);
if(a == '*')
{
x1 = i;
y1 = j;
}
if(a == '.')
{
x2 = i;
y2 = j;
}
}
}
int n = myabs(x1 - x2) + myabs(y1 - y2); // abs取绝对值函数,我自己及声明了一下
if(n % 2) printf("Red win\n");
else printf("Black win\n");
}
return 0;
}