翻翻棋

Description

象棋翻翻棋(暗棋)中双方在4*8的格子中交战,有时候最后会只剩下帅和将。根据暗棋的规则,棋子只能上下左右移动,且相同的级别下,主动移动到地方棋子方将吃掉对方的棋子。将和帅为同一级别。然而胜负在只剩下帅和将的时候已定。

Input

第一行T,表示T组数据。

每组数据共有四行字符串,每行字符串共八个字符

’#’表示空格

’*’表示红方帅

’.’表示黑方将

此时红方先走

每组输入之间没有空行。

Output

每组数据输出一行。若为红方赢输出Red win,否则输出 Black win

Sample Input

1
######.#
#####*##
########
########

Sample Output

Black win


我做题思想是,因为当两个位置按照格子走,走的步数到达另一个格子处的的步数为奇



数时就输出black win;否则red win;



关于此题,我是醉了,首先 用的scanf(“%d”,&a[i][j]),然后我发现自己输入16个数字的时候就自动打印了。然后看了别人的说法,是这样解释的:在

for(i=0;i<4;i++)

{

   for(j=0;j<8;j++)

{   }

getchar();//在这里写getchar接受回车符,就ok了

}

在不知道这样写之前,我就用了gets()来获得每一行;代码如下



#include<stdio.h>
#include <string.h>
int main()
{
    char a[4][8];
    int num;
    char ch;
    scanf("%d",&num);
    ch=getchar();
    while(num--)
    {int step=0;
        int  i,j;
        int x,y,x1,y1;
        for(i=0;i<5;i++)// 把数据写入
        {
            gets(a[i]);
            printf("%s\n",a[i]);
        }

        for(i=0;i<4;i++)//判断‘。’与‘*’的位置。。用我上面所说的绿色字体处写法,可以直接在输入处 判断‘。’与‘*’的位置
            for(j=0;j<8;j++)
        {

            if(a[i][j]=='.')
            {
                x=i;
                y=j;
            }
            if(a[i][j]=='*')
            {
                x1=i;
                y1=j;
            }
        }
        
        if(x1<x)//判断哪个数大。用大的减去小的x轴方向
        {
            step=x-x1;
        }
        else
            step=x-x1;
        if(y<y1)//判断哪个数大。用大的减去小的y轴方向
        {
            step+=y1-y;
        }
        else
            step+=y-y1;
        if(step%2==0)//判断步数的奇偶性
        {
            printf("Red win\n");
        }
        else
            printf("Black win\n");
    }
    return 0;
}


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值