博客
关于我
【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/

    你可能感兴趣的文章
    PHP函数操作数字和汉字互转(100以内)
    查看>>
    PHP函数方法
    查看>>
    PHP创建目录mkdir无写入权限的问题解决方案
    查看>>
    PHP删除指定目录下的所有文件和文件夹 | 删除指定文件
    查看>>
    php删除文件夹下面所有文件包括(删除文件夹)不删除文件夹
    查看>>
    React Collapse Pane 项目教程
    查看>>
    php判断ip黑名单程序代码
    查看>>
    php判断复选框是否被选中的方法
    查看>>
    PHP判断指定目录下是否存在文件
    查看>>
    php判断数组是否为空
    查看>>
    PHP判断数组是否有重复值、获取重复值
    查看>>
    springboot基于Web的社区留守儿童管理系统源码毕设+论文
    查看>>
    Springboot基于Redisson实现Redis分布式可重入锁【案例到源码分析】
    查看>>
    PHP利用正则表达式实现手机号码中间4位用星号(*)替换显示
    查看>>
    PHP加密与安全的最佳实践
    查看>>
    PHP加速器eaccelerator导致php-fpm进程卡死原因分析
    查看>>
    PHP区分 企业微信浏览器 | 普通微信浏览器 | 其他浏览器
    查看>>
    php原生代码怎么连表查询,PHP tp5中使用原生sql查询代码实例
    查看>>
    PHP去掉转义符
    查看>>
    php去除字符串开头或末尾的字符(例如逗号)
    查看>>