【每日一题】LeetCode 3127.构造相同颜色的正方形(数组、枚举、矩阵)

【每日一题】LeetCode 3127.构造相同颜色的正方形(数组、枚举、矩阵)

1. 题目描述

给定一个二维 3 x 3 的矩阵 grid,每个格子都是一个字符,要么是 'B' 表示黑色,要么是 'W' 表示白色。

任务是改变至多一个格子的颜色,使得矩阵中存在一个 2 x 2 颜色完全相同的正方形。

如果可以得到一个相同颜色的 2 x 2 正方形,那么返回 true,否则返回 false

2. 思路分析

要解决这个问题,我们需要检查矩阵中是否存在一个 2 x 2 的子矩阵,使得这个子矩阵中的所有四个格子颜色相同。如果存在,直接返回 true。如果不存在,我们尝试改变一个格子的颜色,再次检查是否存在这样的 2 x 2 子矩阵。

遍历子矩阵

遍历矩阵的每个可能的 2 x 2 子矩阵的左上角位置。

检查颜色

对于每个这样的位置,检查四个相邻格子的颜色是否相同。

返回结果

如果找到符合条件的子矩阵,返回 true

无解返回

如果遍历完所有可能的子矩阵都没有找到,返回 false

3. 输入示例

示例 1

grid = [["B","W","B"],["B","W","W"],["B","W","B"]] 输出:true

示例 2

grid = [["B","W","B"],["W","B","W"],["B","W","B"]] 输出:false

示例 3

grid = [["B","W","B"],["B","W","W"],["B","W","W"]] 输出:true

提示:

grid.length == 3

grid[i].length == 3

grid[i][j] 要么是 'W' ,要么是 'B' 。

4. 代码实现

java 复制代码
class Solution {
    /**
     * 检查是否可以将矩阵中的一个格子颜色改变,使得存在一个2x2的同色正方形。
     * @param grid 给定的二维字符矩阵,包含 'B' 和 'W'。
     * @return 如果可以找到这样的2x2正方形,返回 true,否则返回 false。
     */
    public boolean canMakeSquare(char[][] grid) {
        int row = grid.length; // 矩阵的行数
        int col = grid[0].length; // 矩阵的列数

        // 遍历矩阵,寻找可能的2x2同色正方形的起始点
        for (int i = 0; i < col - 1; i++) {
            for (int j = 0; j < col - 1; j++) {
                // 检查四个相邻的格子是否形成2x2同色正方形
                // 情况1: 左上角和右上角以及左上角和左下角同色
                if (grid[i][j] == grid[i][j + 1] && grid[i][j] == grid[i + 1][j]) {
                    return true;
                }
                // 情况2: 右上角和右下角以及左上角和右下角同色
                else if (grid[i][j + 1] == grid[i][j] && grid[i][j + 1] == grid[i + 1][j + 1]) {
                    return true;
                }
                // 情况3: 右下角和左下角以及左下角和左上角同色
                else if (grid[i][j + 1] == grid[i + 1][j + 1] && grid[i + 1][j] == grid[i + 1][j + 1]) {
                    return true;
                }
                // 情况4: 左下角和左上角以及左下角和右上角同色
                else if (grid[i + 1][j] == grid[i][j] && grid[i + 1][j] == grid[i + 1][j + 1]) {
                    return true;
                }
            }
        }
        // 如果没有找到任何符合条件的2x2同色正方形,返回 false
        return false;
    }
}
相关推荐
董董灿是个攻城狮5 小时前
AI视觉连载8:传统 CV 之边缘检测
算法
怒放吧德德6 小时前
Netty 4.2 入门指南:从概念到第一个程序
java·后端·netty
雨中飘荡的记忆8 小时前
大流量下库存扣减的数据库瓶颈:Redis分片缓存解决方案
java·redis·后端
心之语歌10 小时前
基于注解+拦截器的API动态路由实现方案
java·后端
华仔啊12 小时前
Stream 代码越写越难看?JDFrame 让 Java 逻辑回归优雅
java·后端
ray_liang12 小时前
用六边形架构与整洁架构对比是伪命题?
java·架构
AI软著研究员12 小时前
程序员必看:软著不是“面子工程”,是代码的“法律保险”
算法
FunnySaltyFish12 小时前
什么?Compose 把 GapBuffer 换成了 LinkBuffer?
算法·kotlin·android jetpack
Ray Liang13 小时前
用六边形架构与整洁架构对比是伪命题?
java·python·c#·架构设计
颜酱13 小时前
理解二叉树最近公共祖先(LCA):从基础到变种解析
javascript·后端·算法