【力扣1812】判断国际象棋棋盘中一个格子的颜色

  • 👑专栏内容:力扣刷题
  • ⛪个人主页:子夜的星的主页
  • 💕座右铭:前路未远,步履不停

目录


一、题目描述

题目链接:判断国际象棋棋盘中一个格子的颜色

给你一个坐标 coordinates ,它是一个字符串,表示国际象棋棋盘中一个格子的坐标。下图是国际象棋棋盘示意图。

如果所给格子的颜色是白色,请你返回 true,如果是黑色,请返回 false 。给定坐标一定代表国际象棋棋盘上一个存在的格子。坐标第一个字符是字母,第二个字符是数字。

二、题目分析

这道题下面的a,b,c啥的很讨厌,因为不是数字。

但我们可以通过字符的 ASCII 码值进行转换,例如'a' - 'a'的结果就是0;

题目给的是两个字符,我们可以用String类里面的charAt 方法获取字符。

charAt 方法是 Java 中 String 类的一个方法,用于获取字符串中指定位置的字符。该方法的语法如下:

java 复制代码
char charAt(int index)

这个方法接受一个整数参数 index,表示要获取的字符的位置。字符串中的索引从 0 开始,即第一个字符的索引是 0,第二个字符的索引是 1,以此类推。如果 index 超出字符串的有效范围,会抛出 StringIndexOutOfBoundsException 异常。

知道了这个后,我们就可以把象棋棋盘上的格子转化为坐标。

例如'a1'我们就可以用如下代码:

java 复制代码
int a = coordinates.charAt(0) - 'a';
int b = coordinates.charAt(1) - '1';

这样'a1'就被我们转化为了00

我们观察一下象棋盘,会发现,当转化为坐标后,x坐标 + y坐标的和为偶数就为黑色,为奇数就为白色。所以这道题就非常简单了。

java 复制代码
class Solution {
    public boolean squareIsWhite(String coordinates) {
        int a = coordinates.charAt(0);
        int b = coordinates.charAt(1);
        if((a+b) % 2 == 0){
            return false;
        }else{
            return true;
        }
    }
}
相关推荐
范纹杉想快点毕业2 分钟前
C语言100个经典编程练习题(完整标题+清晰排版)
运维·c语言·单片机·嵌入式硬件·算法
Tisfy4 分钟前
LeetCode 2943.最大化网格图中正方形空洞的面积:小小思维
算法·leetcode·题解·数组·思维·排序·连续
LDG_AGI6 分钟前
【机器学习】深度学习推荐系统(二十六):X 推荐算法多模型融合机制详解
人工智能·分布式·深度学习·算法·机器学习·推荐算法
高山上有一只小老虎8 分钟前
小红的矩阵染色
java·算法·矩阵
WuChao_JMUer8 分钟前
YOLO26 on RDK S100P 端侧部署技术报告
人工智能·算法·yolo·rdk
Ro Jace8 分钟前
传统雷达信号分选方法之SDIF:Improved algorithm for the deinterleaving of radar pulses
网络·人工智能·算法
小杨同学4910 分钟前
【嵌入式 C 语言实战】手动实现字符串四大核心函数(strcpy/strcat/strlen/strcmp)
后端·深度学习·算法
Gofarlic_OMS15 分钟前
MATLAB许可证闲置自动检测与智能提醒
java·大数据·运维·开发语言·人工智能·算法·matlab
工业甲酰苯胺18 分钟前
推荐算法闲谈:如何在不同业务场景下理解和拆解核心指标
算法·机器学习·推荐算法
平生不喜凡桃李20 分钟前
LeetCode: 基本计算器详解
算法·leetcode·计算器·逆波兰表达式