1099: 孤独的骑士

题目描述
任务很简单. 确定国际象棋棋盘上处于骑士攻击之下的格子个数. 棋盘上没有其它棋子. 骑士的走法: 横(纵)向走两个格, 再纵(横)向走一个格(类似于中国象棋中的马).

输入
第一行为测试次数N, 1 ≤ N ≤ 100.
后面N行每行包含一个坐标表示骑士的位置.
字母表示横向位置, 数字表示纵向位置.

输出
输出N行. 每行一个整数, 表示骑士可攻击的格子个数.

样例输入
3
a1
d4
g6

样例输出
2
8
6

import java.util.Scanner;//输入包

public class Main {
    public static void main(String[] args) {
        Scanner cn = new Scanner(System.in);//输入流
        int n = cn.nextInt();
        while (n-- > 0) {//进行多组输入判断
            String str = cn.next();
            char[] c = str.toCharArray();
            int counts = 0;
            if (c[0] - 2 >= 'a' && c[1] - '1' >= 1) { 
                counts++;
            }
            if (c[0] - 2 >= 'a' && '8' - c[1] >= 1) {
                counts++;
            }
            if (c[1] - 2 >= 49 && c[0] - 1 >= 'a') {
                counts++;
            }
            if (c[1] - 2 >= 49 && 'h' - c[0] >= 1) {
                counts++;
            }
            if ('8' - c[1] >= 2 && c[0] - 1 >= 97) {
                counts++;
            }
            if ('8' - c[1] >= 2 && 'h' - c[0] >= 1) {
                counts++;
            }
            if ('h' - c[0] >= 2 && c[1] - 1 >= 49) {
                counts++;
            }
            if ('h' - c[0] >= 2 && '8' - c[1] >= 1) {
                counts++;
            }
            System.out.println(counts);

        }
        cn.close();
    }
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值