有效的数独

这篇具有很好参考价值的文章主要介绍了有效的数独。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

题目链接

有效的数独

题目描述

有效的数独,算法,数据结构,leetcode,算法,java
有效的数独,算法,数据结构,leetcode,算法,java
有效的数独,算法,数据结构,leetcode,算法,java文章来源地址https://www.toymoban.com/news/detail-739628.html

注意点

  • board.length == 9
  • board[i].length == 9
  • board[i][j] 是一位数字(1-9)或者 ‘.’

解答思路

  • 首先判断行是否满足数独条件,再判断列是否满足数独条件,最后再判断划分的3x3方格是否满足数独条件,中间有一处不满足则直接返回false,遍历完后都满足条件则返回true

代码

class Solution {
    public boolean isValidSudoku(char[][] board) {
        int row = board.length;
        int col = board[0].length;
        // 判断行
        for (int i = 0; i < row; i++) {
            int[] arr = new int[10];
            for (int j = 0; j < col; j++) {
                if (board[i][j] == '.') {
                    continue;
                }
                if (arr[board[i][j] - '0'] != 0) {
                    return false;
                }
                arr[board[i][j] - '0'] = 1;
            }
        }
        // 判断列
        for (int j = 0; j < col; j++) {
            int[] arr = new int[10];
            for (int i = 0; i < row; i++) {
                if (board[i][j] == '.') {
                    continue;
                }
                if (arr[board[i][j] - '0'] != 0) {
                    return false;
                }
                arr[board[i][j] - '0'] = 1;
            }
        }
        // 判断3 x 3方格
        for (int i = 0; i < row; i = i + 3) {
            for (int j = 0; j < col; j = j + 3) {
                if (!isValidSudokuSquare(board, i, j)) {
                    return false;
                }
            }
        }
        return true;
    }

    public boolean isValidSudokuSquare(char[][] board, int x, int y) {
        int[] arr = new int[10];
        for (int i = 0; i < 3; i++) {
            for (int j = 0; j < 3; j++) {
                if (board[x + i][y + j] == '.') {
                    continue;
                }
                if (arr[board[x + i][y + j] - '0'] != 0) {
                    return false;
                }
                arr[board[x + i][y + j] - '0'] = 1; 
            }
        }
        return true;
    }
}

关键点

  • 有效数独的条件

到了这里,关于有效的数独的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • LeetCode 36题:有效的数独

    请你判断一个  9 x 9  的数独是否有效。只需要  根据以下规则  ,验证已经填入的数字是否有效即可。 数字  1-9  在每一行只能出现一次。 数字  1-9  在每一列只能出现一次。 数字  1-9  在每一个以粗实线分隔的  3x3  宫内只能出现一次。(请参考示例图) 注意: 一个有

    2024年02月12日
    浏览(34)
  • 【面试经典150 | 矩阵】有效的数独

    本专栏专注于分析与讲解【面试经典150】算法,两到三天更新一篇文章,欢迎催更…… 专栏内容以分析题目为主,并附带一些对于本题涉及到的数据结构等内容进行回顾与总结,文章结构大致如下,部分内容会有增删: Tag:介绍本题牵涉到的知识点、数据结构; 题目来源:

    2024年02月05日
    浏览(41)
  • C++面试宝典第31题:有效的数独

    题目         判断一个9 x 9的数独是否有效。只需要根据以下规则,验证已经填入的数字是否有效即可。         1、数字1-9在每一行只能出现一次。         2、数字1-9在每一列只能出现一次。         3、数字1-9在每一个以粗实线分隔的3 x 3宫内只能出现一次。

    2024年02月22日
    浏览(36)
  • 力扣题库刷题笔记36--有效的数独

    1、题目如下:  2、个人Python代码实现如下: 3、个人Python代码思路:         先放一个AI解释的思路:         个人理解,本题思路其实很简单,判断每一行、每一列、每一个3*3的子数独是否存在重复数字,如果存在则返回False,如果不存在则返回True。         1、首先

    2024年02月13日
    浏览(48)
  • 矩阵&滑动窗口|36. 有效的数独 3. 无重复字符的最长子串

    题目 :请你判断一个 9 x 9 的数独是否有效。只需要 根据以下规则 ,验证已经填入的数字是否有效即可。 数字 1-9 在每一行只能出现一次。 数字 1-9 在每一列只能出现一次。 数字 1-9 在每一个以粗实线分隔的 3x3 宫内只能出现一次。(请参考示例图) 题目链接 :有效的数独

    2024年01月18日
    浏览(50)
  • C语言 | Leetcode C语言题解之第36题有效的数独

    题目: 题解:

    2024年04月22日
    浏览(39)
  • Flutter编写的数独游戏

    一个使用Flutter编写的每日数独小🎮游戏,支持Android和ios。代码已上传到github:https://github.com/huhx/flutter_sudoku 状态管理:flutter_hooks + hooks_riverpod UI:flutter_slidable + sticky_headers + badges + flex_color_scheme 依赖注入:get_it 夜间模式:使用flex_color_scheme定制夜间模式和亮丽模式 难度可调

    2024年02月05日
    浏览(84)
  • 【数据结构与算法】6、栈(Stack)的实现、LeetCode:有效的括号

    🌱 栈 是一种特殊的线性表, 只能在一端进行操作 🌱 往栈中 添加 元素的操作,一般叫做 push ( 入栈 ) 🌱 从栈中 移除 元素的操作,一般叫做 pop ,出栈(只能移除栈顶元素),也叫做: 弹出栈顶元素 🌱 后进先出 的原则, L ast I n F irst O ut, LIFO 注意:这里的 栈 与内

    2024年02月13日
    浏览(39)
  • 数据结构与算法之字符串: Leetcode 20. 有效的括号 (Typescript版)

    有效的括号 https://leetcode.cn/problems/valid-parentheses/ 描述 给定一个只包括 ‘(’,‘)’,‘{’,‘}’,‘[’,‘]’ 的字符串 s ,判断字符串是否有效。 有效字符串需满足: 左括号必须用相同类型的右括号闭合。 左括号必须以正确的顺序闭合。 每个右括号都有一个对应的相

    2024年02月01日
    浏览(54)
  • Rust每日一练(Leetday0012) 首末位置、插入位置、有效数独

    目录 34. 查找元素的首末位置 Find-first-and-last-position-of-element-in-sorted-array  🌟🌟 35. 搜索插入位置 Search Insert Position  🌟 36. 有效的数独 Valid Sudoku  🌟🌟 🌟 每日一练刷题专栏 🌟 Rust每日一练 专栏 Golang每日一练 专栏 Python每日一练 专栏 C/C++每日一练 专栏 Java每日一练 专

    2024年02月09日
    浏览(47)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包