博客
关于我
【leetcode-数组】有效的数独
阅读量:552 次
发布时间:2019-03-09

本文共 1353 字,大约阅读时间需要 4 分钟。

要判断一个9x9数独是否有效,需要确保每一行、每一列以及每个3x3的小宫内的数字1-9不重复。通过以下步骤可以有效地实现这个检查:

方法思路

  • 初始化辅助数组:创建三个9x9的布尔数组,分别用于记录每一行、每一列和每个小宫内的数字是否重复。
  • 遍历整个网格:逐个检查每个格子的值。
  • 处理已填数字:对于非'.'的格子,将其转换为数字,检查是否存在重复。
  • 行、列和宫检查:确保当前数字不在同一行、列或小宫中已存在。
  • 立即返回冲突:一旦发现重复,立即返回false。
  • 返回有效性:如果遍历无误,返回true。
  • 代码示例

    public class Solution {    public boolean isValidSudoku(char[][] board) {        boolean[][] rowFlag = new boolean[9][9];        boolean[][] colFlag = new boolean[9][9];        boolean[][] cellFlag = new boolean[9][9];                int m = board.length;        int n = board[0].length;                for (int i = 0; i < m; i++) {            for (int j = 0; j < n; j++) {                char cc = board[i][j];                if (cc != '.' && cc != '0') {                    int c = cc - '0';                    if (rowFlag[i][c] || colFlag[j][c] || cellFlag[3 * (i / 3) + (j / 3)][c]) {                        return false;                    }                    rowFlag[i][c] = true;                    colFlag[j][c] = true;                    cellFlag[3 * (i / 3) + (j / 3)][c] = true;                }            }        }        return true;    }}

    详细步骤

  • 初始化辅助数组:创建三个布尔数组,行、列和小宫存储是否存在重复数字。
  • 遍历每个格子:通过双重循环遍历整个9x9网格。
  • 检查当前格子:如果格子为空,继续下一个;如果是数字,转换为整数。
  • 复制当前行、列和宫的信息:检查当前数字是否在同一行、列或小宫中已存在。
  • 记录检查结果:如果已存在,返回false,表明数独无效。
  • 标记当前数字:如果检查通过,标记当前数字,避免重复检查。
  • 最终判断:如果遍历完无错误,返回true,数独有效。
  • 这样,可以高效地判断数独是否有效,满足规则要求。

    转载地址:http://ivhiz.baihongyu.com/

    你可能感兴趣的文章
    oppo后端16连问
    查看>>
    Optional类:避免NullPointerException
    查看>>
    Optional讲解
    查看>>
    ORA-00932: inconsistent datatypes: expected - got NCLOB【ORA-00932: 数据类型不一致: 应为 -, 但却获得 NCLOB 】【解决办法】
    查看>>
    ORA-00942 表或视图不存在
    查看>>
    ORA-01034: ORACLE not available
    查看>>
    ORA-01152: 文件 1 没有从过旧的备份中还原
    查看>>
    ORA-01207:文件比控制文件更新 - 旧的控制文件
    查看>>
    ORA-01795: 列表中的最大表达式数为 1000
    查看>>
    ORA-06575: 程序包或函数 NO_VM_DROP_PROC 处于无效状态
    查看>>
    ORA-08102的错误
    查看>>
    ORA-12505, TNS:listener does not currently know of SID given in connect descriptor异常
    查看>>
    ORA-12514: TNS:listener does not currently know of service问题原因
    查看>>
    ora-12541:tns:no listener
    查看>>
    【docker知识】联合文件系统(unionFS)原理
    查看>>
    ORACEL学习--理解over()函数
    查看>>
    ORAchk-数据库健康检查
    查看>>
    oracle 10g crs命令,Oracle 10g CRS安装问题解决一例
    查看>>
    Oracle 10g ORA-01034: ORACLE not available 错误
    查看>>
    oracle 10g的安装配置
    查看>>