有效的数独-java

  • 题目描述:

  • 请你判断一个 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.hqwc.cn/news/576721.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

在Three.js中,EXRExporter API通常用于将场景导出为EXR(OpenEXR)格式的图像。

demo案例 在Three.js中&#xff0c;EXRExporter API通常用于将场景导出为EXR&#xff08;OpenEXR&#xff09;格式的图像。下面是对其入参、出参、方法和属性的详细解释&#xff1a; 入参&#xff08;输入参数&#xff09;&#xff1a; scene&#xff08;场景&#xff09;&…

高效物联网连接技术创新:ECWAN边缘协同自组网的未来——基于ChirpLAN窄带扩频技术的无线混合组网

物联网是指将各种物理设备通过互联网进行连接和通信的技术。它是一个庞大的网络&#xff0c;由传感器、设备、网络和云服务组成&#xff0c;旨在实现对物体的远程监测、控制和数据采集。 基于ChirpLAN窄带扩频技术的无线混合组网协议ChirpLAN&#xff0c;ChirpLAN是基于其自有的…

【超图 SuperMap3D】【基础API使用示例】51、超图SuperMap3D - 绘制圆|椭圆形面标注并将视角定位过去

前言 引擎下载地址&#xff1a;[添加链接描述](http://support.supermap.com.cn/DownloadCenter/DownloadPage.aspx?id2524) 绘制圆形或者椭圆形效果 核心代码 entity viewer.entities.add({// 圆中心点position: { x: -1405746.5243351874, y: 4988274.8462937465, z: 370…

岭师大数据技术原理与应用-序章-软工版

HeZaoCha-CSDN博客 序章—软工版 一、环境介绍1. VMware Workstation Pro2. CentOS3. Java4. Hadoop5. HBase6. MySQL7. Hive 二、系统安装1. 虚拟网络编辑器2. 操作系统安装 三、结尾 先说说哥们写这系列博客的原因&#xff0c;本来学完咱也没想着再管部署这部分问题的说&…

Jackson 2.x 系列【6】注解大全篇二

有道无术&#xff0c;术尚可求&#xff0c;有术无道&#xff0c;止于术。 本系列Jackson 版本 2.17.0 源码地址&#xff1a;https://gitee.com/pearl-organization/study-jaskson-demo 文章目录 注解大全2.11 JsonValue2.12 JsonKey2.13 JsonAnySetter2.14 JsonAnyGetter2.15 …

新华保险失速?业绩负增长,“欺骗投保人”问题屡罚屡犯

近日&#xff0c;新华保险&#xff08;601336.SH、01336.HK&#xff09;披露了2023年全年财报。贝多财经发现&#xff0c;该公司营收和利润出现双位数下滑&#xff0c;即便身处寿险市场回暖的大环境下&#xff0c;该公司今年以来的原保险保费收入也处于下跌态势。 即便新华保险…

Elastic 8.13:Elastic AI 助手中 Amazon Bedrock 的正式发布 (GA) 用于可观测性

作者&#xff1a;来自 Elastic Brian Bergholm 今天&#xff0c;我们很高兴地宣布 Elastic 8.13 的正式发布。 有什么新特性&#xff1f; 8.13 版本的三个最重要的组件包括 Elastic AI 助手中 Amazon Bedrock 支持的正式发布 (general availability - GA)&#xff0c;新的向量…

免费在线制流程图和思维导图ProcessOn高效协同

免费在线制流程图和思维导图ProcessOn高效协同&#xff0c;还有海量的免费模板。在ProcessOn&#xff0c;你可以与全球超过1.1亿的优秀人才一起合作&#xff0c;共同绘制出精美的流程图和思维导图。无论是工作中的项目管理&#xff0c;还是学习中的知识整理&#xff0c;Process…

GESP Python编程二级认证真题 2024年3月

Python 二级 2024 年 03 月 1 单选题&#xff08;每题 2 分&#xff0c;共 30 分&#xff09; 第 1 题 小杨的父母最近刚刚给他买了一块华为手表&#xff0c;他说手表上跑的是鸿蒙&#xff0c;这个鸿蒙是&#xff1f;&#xff08; &#xff09; A. 小程序 B. 计时器 C. 操作系统…

动态规划刷题(算法竞赛、蓝桥杯)--导弹拦截(线性DP)

1、题目链接&#xff1a;[NOIP1999 提高组] 导弹拦截 - 洛谷 #include <bits/stdc.h> using namespace std; const int N2e55; int a[N],x,n; int b[N],len;int main(){while(cin>>x)a[n]x;//求最长不上升子序列 b[0]2e9;//初始化为无穷大for(int i1;i<n;i){if(…

Immunity(IF=32.4)|空间多组学揭示免疫检查点联合疗法响应机制

免疫检查点疗法&#xff08;immune checkpoint blockade&#xff0c;ICB&#xff09;已经在肿瘤疾病中得到了广泛应用&#xff0c;但部分患者依然出现低应答甚至不应答的现象。因此开发新型免疫疗法是解决患者低响应的关键。aPD-L1aCTLA4联合治疗是目前研究最广泛的联合疗法之一…

如何在CentOS使用Docker搭建Rsshub服务并实现无公网IP远程访问

文章目录 1. Docker 安装2. Docker 部署Rsshub3. 本地访问Rsshub4. Linux安装Cpolar5. 配置公网地址6. 远程访问Rsshub7. 固定Cpolar公网地址8. 固定地址访问 Rsshub是一个开源、简单易用、易于扩展的RSS生成器&#xff0c;它可以为各种内容生成RSS订阅源。 Rsshub借助于开源社…