2025年--Lc169--H36.有效的数独(矩阵)--Java版

1.题目

2.思路

(1)用二维数组rows存储行数组

(2)用二维数组column存储列数组

(3)用三维数组存储9个小矩阵(三行三列总共9个小矩阵)

遇到一个元素,则对该元素的行数组和列数组都进行计数,如果行数组和列数组的计数分别大于1,返回false;以及如果9个小矩阵的计数也大于1,则返回false;

例子:

假设在 (i=0, j=1) 位置看到字符 '5':

如果在同一行/列/子宫格里再次遇到 '5',对应位置的计数会变为 2,你就可以判定数独无效

java 复制代码
int index = '5' - '1'; // 4
rows[0][4]++        // 第0行的"数字5"计数+1
columns[1][4]++     // 第1列的"数字5"计数+1
subboxes[0/3][1/3][4]++  // subboxes[0][0][4]++:左上角子宫格里的"数字5"计数+1

3.代码实现

java 复制代码
class Solution {
    public boolean isValidSudoku(char[][] board) {
        int[][] rows=new int[9][9];
        int[][] column=new int[9][9];
        int[][][] sub=new int[3][3][9];
        for(int i=0;i<9;i++)
        {
            for(int j=0;j<9;j++)
            {
                char c=board[i][j];
                if(c!='.')
                {
                    int index=c-'0'-1;
                    rows[i][index]++;
                    column[j][index]++;
                    sub[i/3][j/3][index]++;
                    //这边的[index]代表当前的字符
                    if(rows[i][index]>1||column[j][index]>1||sub[i/3][j/3][index]>1)
                    {
                        return false;
                    }

                }
            }
        }
        return true;
        
    }
}
相关推荐
Zaly.3 小时前
【Python刷题】LeetCode 1727 重新排列后的最大子矩阵
算法·leetcode·矩阵
2301_7665586510 小时前
本地部署+云端优化:矩阵跃动龙虾机器人,实现7×24小时AI获客无人值守
人工智能·矩阵·机器人
Tisfy10 小时前
LeetCode 3643.垂直翻转子矩阵:原地修改
算法·leetcode·矩阵·模拟
wyiyiyi10 小时前
【线性代数】对偶空间与矩阵转置及矩阵分解(Java讲解)
java·线性代数·支持向量机·矩阵·数据分析
Frostnova丶12 小时前
LeetCode 3643.子矩阵垂直翻转算法解析
算法·leetcode·矩阵
ryrhhhh12 小时前
AI流量闭环搭建指南:矩阵跃动龙虾机器人+GEO,从占位到转化全自动化
人工智能·矩阵·机器人
ryrhhhh13 小时前
矩阵跃动自研技术:小陌GEO动态监测算法,30分钟快速适配大模型更新
人工智能·算法·矩阵
2501_9431240513 小时前
7×24小时自动运营:矩阵跃动龙虾机器人,AI流量闭环效率拉满
人工智能·矩阵·机器人
沉睡的无敌雄狮13 小时前
AI优化效果不可控?矩阵跃动龙虾机器人,数据驱动排名稳定提升
人工智能·矩阵·机器人
2301_7665586514 小时前
矩阵跃动OpenClaw龙虾机器人:本地AI智能体+GEO优化,企业流量自动化落地
人工智能·矩阵·机器人