有效的数独-java

news2025/1/22 15:52:59
  • 题目描述:

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

    • 一个有效的数独(部分已被填充)不一定是可解的。
    • 只需要根据以上规则,验证已经填入的数字是否有效即可。
    • 空白格用 '.' 表示。

 

  • 一, 解题思想 :
    • 这段代码是用来检查一个数独是否是合法的。它的思路是利用三个二维数组分别记录每一行、每一列和每个九宫格中除了'.'之外的数字出现的次数。

      1. 创建三个二维数组 `rows`, `columns`, `box`,分别用来记录每一行、每一列和每个九宫格中数字的出现次数。
      2. 使用两个嵌套的循环遍历整个数独表格。
      3. 对于每一个非'.'的数字,通过计算其在行、列和九宫格中的索引,更新相应的 `rows`, `columns`, `box` 数组中对应位置的计数器。
      4. 在更新计数器时,使用 `++` 操作符自增,同时检查是否出现重复数字,如果出现重复数字,则直接返回 `false`,表示该数独不合法。
      5. 如果遍历完成没有发现重复数字,则返回 `true`,表示该数独是合法的。

      这个算法的时间复杂度为 O(n^2),其中 n 是数独的边长。因为它只需要一次遍历整个数独表格,并且在每次遍历时只需要常数时间来更新计数器。

    • 二, 解题步骤:
      • 初始化数组:
        •  创建三个二维数组 rowscolumnsbox用来记录每一行、每一列和每个九宫格中数字的出现次数。,每个数组的初始值都是 0。
      • 遍历数独表格: 
        • 使用两个嵌套的循环遍历整个数独表格。外层循环控制行,内层循环控制列

      • 更新计数器: 
        • 对于每一个非'.'的数字,即非空格的情况,计算其在行、列和九宫格中的索引,并更新相应的 rowscolumnsbox 数组中对应位置的计数器。这里要注意的是,由于数组索引从0开始,需要将数字减去 '1' 来得到相应的索引值。例如,数字 '1' 对应的索引是 0,数字 '2' 对应的索引是 1,以此类推。

          • for (int i = 0; i < 9; i++) {
                        for (int j = 0; j < 9; j++) {
                            if (board[i][j] != '.') {
                                int digit = board[i][j] - '1';
            
                            }
                        }
                    }

      • 检查重复数字:

        •  在更新计数器时,使用 ++ 操作符自增,同时检查是否出现重复数字。具体做法是将当前位置对应的 rowscolumnsbox 数组中的值相乘,如果结果大于 1,说明当前位置的数字在该行、列或九宫格中已经出现过,即存在重复数字,此时直接返回 false,表示该数独不合法。

        • if(++rows[i][digit] * ++columns[j][digit] * ++box[i / 3][j / 3][digit] > 1)
                                  return false;
        • 返回结果:

          •  如果遍历完成没有发现重复数字,则返回 true,表示该数独是合法的。

      • 这个算法的关键在于通过三个数组分别记录每一行、每一列和每个九宫格中数字的出现次数,并在遍历过程中实时更新这些计数器,以便及时检查是否存在重复数字。

    • 以下是完整的代码 : (已在力扣通过, 运行时间 : 1ms, 消耗内存分布: 43.17MB)

  • class Solution {
        public boolean isValidSudoku(char[][] board) {
            int[][] rows = new int[9][9]; //  记录每一行中除0外的数字的次数
            int[][] columns = new int[9][9]; //  记录每一列中除0外的数字的次数
            int[][][] box = new int[3][3][9]; //  记录每个九宫格中除0外的数字的次数
    
            for (int i = 0; i < 9; i++) {
                for (int j = 0; j < 9; j++) {
                    if (board[i][j] != '.') {
                        int digit = board[i][j] - '1';
                        
                    if(++rows[i][digit] * ++columns[j][digit] * ++box[i / 3][j / 3][digit] > 1)
                            return false;
                    }
                }
            }
            return true;
        }
    }

        

  •                 以上是本篇博客的全部内容,感谢观看.

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1553722.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

C++实现A*路径规划的库

作者&#xff1a;CodeLikeAGirl 编译&#xff1a;东岸因为一点人工一点智能公众号 C实现A*路径规划的库本文中&#xff0c;我们探索了A*路径规划在Robotic Project C中的迷人世界&#xff0c;了解了一些超酷的C库。https://mp.weixin.qq.com/s/WyTIzkmWS-0t5oaII6or-Q 01 A*…

ventoy_grub2_boot_win7_win10.md

ventoy (grub2) 的 extMenu启动 win7 efi 、win10 efi ventoy界面按F6&#xff08;extMenu菜单&#xff09; 弹出 ventoy/ventoy_grub.cfg中的菜单内容 ventoy (grub2) 的 extMenu启动 win7 efi 1. 生成 老式 分区启动记录 EFI\Microsoft\Boot\bootmgfw.efi: 命令: bcdboot…

知识图谱构建三要素:实体、关系与属性技术与实战全解析

目录 一、知识图谱三要素简介实体&#xff08;Entity&#xff09;的重要性关系&#xff08;Relationship&#xff09;的作用属性&#xff08;Attribute&#xff09;的应用 二、实体&#xff08;Entity&#xff09;理论介绍实体的概念细节实体的分类实体识别的技术细节实体识别的…

element plus的el-image图片发布到nginx不显示

问题&#xff1a; <el-image alt""src"/img/month-b.png" class"card-icon"style"width: 89px;height: 89px;right: -7px;top: -5px;"/> 部署到nginx二级路由访问地址是&#xff1a; http://192.168.1.207/divided/# 这时候使用…

大咖论道 | RPA与AI在企业数字化转型中的角色与未来

前言&#xff1a;在ISIG-RPA峰会的圆桌论坛中&#xff0c;由中投创展创始人兼CEO任威主持了关于企业自动化转型的深入讨论&#xff0c;嘉宾包括UiPath大中华区资深技术经理王栊、SAP业务技术平台卓越中心方案架构师阎韶华和三井住友保险中国区信息技术部负责人陈婧。 讨论焦点…

Acwing_795前缀和 【一维前缀和】+【模板】二维前缀和

Acwing_795前缀和 【一维前缀和】 题目&#xff1a; 代码&#xff1a; #include <bits/stdc.h> #define int long long #define INF 0X3f3f3f3f #define endl \n using namespace std; const int N 100010; int arr[N];int n,m; int l,r; signed main(){std::ios::s…

吴恩达2022机器学习专项课程(一) 4.2 梯度下降实践

问题预览/关键词 本节内容梯度下降更新w的公式梯度下降更新b的公式的含义α的含义为什么要控制梯度下降的幅度&#xff1f;导数项的含义为什么要控制梯度下降的方向&#xff1f;梯度下降何时结束&#xff1f;梯度下降算法收敛的含义正确更新梯度下降的顺序错误更新梯度下降的顺…

6.RGB转YCbcr

1.方法 RGB转灰度有很多种方式   1.将RGB中任意分量拿出来当做灰度值。   2.取RGB三通道的均值来当灰度值。   3.将RGB转YUV(YCbCr)然后取Y分量作为灰度值。   其余的几种实现方式较为简单&#xff0c;这里不做介绍。重点实现RGB转YCbCr。 1.1 YUV(YCbCr)格式 Y表示亮…

Web开发-Django学习笔记

客户端如何获取服务端的数据信息&#xff1f; 通常 是 HTTP网络协议&#xff0c;通过网络传输数据信息。 客户端通过HTTP协议发送请求信息给服务端&#xff0c;并从服务端接收响应信息。 Web 前端开发&#xff1a; &#xff08;HTML、CSS、JS&#xff09;文件部署在后端服务…

华为广告打包报错,问题思考

华为广告打包时报错 fata日志不一样能反映出完整的错误日志信息&#xff0c;仅看fata日志具有误导性&#xff0c;有可能指向错误的方向。 通过看完整的日志可见&#xff0c;错误的原因为 Caused by: java.lang.ClassNotFoundException: com.huawei.hms.ads.base.R$dimenfata日…

Java基础概念(二)

idea 工欲善其事&#xff0c;必先利其器&#xff0c;所以在真正编写代码之前先下载idea工具&#xff0c;idea是用于java语言开发的集成环境&#xff0c;是业界目前公认的用于Java开发最好的工具&#xff0c;把代码编写、编译、运行、调试等功能综合到一起的开发工具 下载地址…

解决npm init vue@latest证书过期问题:npm ERR! code CERT_HAS_EXPIRED

目录 一. 问题背景 二. 错误信息 三. 解决方案 3.1 临时解决办法 3.2 安全性考量 一. 问题背景 我在试图创建一个新的Vue.js项目时遇到了一个问题&#xff1a;npm init vuelatest命令出现了证书过期的错误。不过这是一个常见的问题&#xff0c;解决起来也简单。 二. 错误…

uni-app项目打包步骤和踩过的坑(一)

最近接了一个前同事留下的uni-app的项目&#xff0c;之前没有接触过&#xff0c;好在以前的工作中用到过vue做过前台开发&#xff0c;虽然时间不长&#xff0c;但是有些方面还是可以借鉴的。经过前几篇文章的介绍&#xff0c;我已经补完了后台服务代码&#xff0c;打算发布到设…

QT布局管理和空间提升为和空间间隔

QHBoxLayout&#xff1a;按照水平方向从左到右布局&#xff1b; QVBoxLayout&#xff1a;按照竖直方向从上到下布局&#xff1b; QGridLayout&#xff1a;在一个网格中进行布局&#xff0c;类似于HTML的table&#xff1b; 基本布局管理类包括&#xff1a;QBoxLayout、QGridL…

AI人像写真解决方案,满足企业多样化视觉需求

美摄科技&#xff0c;作为一家专注于人工智能技术研发与应用的高新企业&#xff0c;深知企业对于高质量、高效率视觉内容的需求&#xff0c;特推出AI人像写真解决方案&#xff0c;为企业打开全新的视觉营销通道。 我们的AI人像写真解决方案&#xff0c;基于深度学习和计算机视…

3D分割项目 | 基于Pytorch+3DUnet实现的3D体积语义分割算法

项目应用场景 用于 3D 体积语义分割场景&#xff0c;适用于各种物体的 3D 语义分割&#xff0c;比如大米、大豆的体积分割等 项目效果&#xff1a; 项目流程 > 具体参见项目内README.md (1) 安装 conda install -c conda-forge mamba mamba create -n pytorch-3dunet -c p…

第十四届蓝桥杯JavaA组省赛真题 - 互质数的个数

解题思路&#xff1a; 快速幂 欧拉函数 快速幂比较常见于数据较大的取模场景&#xff0c;欧拉函数感觉还是有点抽象 注意&#xff1a; 取模的时候就不要简写了&#xff0c;例如&#xff1a;res res * a % mod;不要写成res * a % mod; import java.util.Scanner;public c…

cesium vue 绘制标记实体(撒点),监听鼠标左击事件

添加实体 const viewer new Cesium.Viewer(cesiumContainer, {})viewer.entities.add()查看实体 const viewer new Cesium.Viewer(cesiumContainer, {}) const billboard viewer.entities.add({...})viewer.zoomTo(billboard)删除实体 根据实体删除 if (billboard.value…

ElementUI 周组件展示成月的第几周

ElementUI 周组件展示成月的第几周 组件展示 <el-date-picker unlink-panels :clearable"false" change"weekChange":editable"false" :type"dateType":value-format"valueFormat" :format"format"v-if&qu…

怎样一次性给多篇word文档标注拼音?一键批量注音

随着办公自动化的普及&#xff0c;我们经常会遇到需要处理大量Word文档的情况。在这些文档中&#xff0c;有时需要将文字标注上拼音&#xff0c;特别是在处理一些包含生僻字或需要拼音辅助阅读的文档时。然而&#xff0c;手动一篇篇地给Word文档标注拼音不仅效率低下&#xff0…