首页 > 编程语言 >用JavaScript来优化数独验证的过程

用JavaScript来优化数独验证的过程

时间:2024-07-03 09:41:29浏览次数:29  
标签:遍历 数字 验证 JavaScript 网格 每列 棋盘 数独

问题陈述 给定一个 9x9 数独棋盘,确定它是否有效。棋盘由一个二维数组表示,其中空单元格用 表示'.'。有效的数独棋盘满足以下规则: 每行必须包含数字 1–9,且不能重复。 每列必须包含数字 1–9,且不能重复。 九个 3x3 子网格中的每一个都必须包含数字 1–9,且不能重复。

初步方法 一种简单的方法可能涉及对每行、每列和每个子网格进行单独检查。这通常需要多次检查棋盘,从而导致时间复杂度增加。但是,我们可以通过在一次检查中检查所有三个约束来优化这一点。 优化解决方案 我们可以维护三组集合来跟踪每行、每列和 3x3 子网格中看到的数字。这样,我们遍历棋盘一次,同时检查所有约束

解释 初始化:创建三个集合数组: rows:跟踪每行中看到的数字。 cols:跟踪每列中看到的数字。 boxes:追踪每个 3x3 子网格中看到的数字。 单次遍历:遍历棋盘上的每一个单元格: 如果单元格为空,则跳过该单元格 ( '.')。 使用 计算子网格索引Math.floor(i / 3) * 3 + Math.floor(j / 3)。 检查当前数字是否已经出现在相应的行、列或子网格中。 如果有,请false立即返回。 否则,将该数字添加到相应的集合中。 返回:如果遍历结束时没有发现重复项,则返回true。

优化方法的好处 效率:棋盘仅被遍历一次,由于棋盘大小固定(9x9),因此解决方案的时间复杂度为 O(1)。 清晰度:使用集合使得逻辑变得直接且易于理解。 简单:通过在单个循环中处理行、列和子网格,代码保持干净、简洁。

标签:遍历,数字,验证,JavaScript,网格,每列,棋盘,数独
From: https://www.cnblogs.com/jiangyueniannian/p/18280997

相关文章

  • WebStorm 2024 for Mac JavaScript前端开发工具
    Mac分享吧文章目录效果一、下载软件二、开始安装1、双击运行软件(适合自己的M芯片版或Intel芯片版),将其从左侧拖入右侧文件夹中,等待安装完毕2、应用程序显示软件图标,表示安装成功3、打开访达,点击【文稿】。将安装包内的【ja-netfilter】文件夹拖到文稿中4、填写内容,修改用......
  • JavaScript-WebAPI
    文章目录JS组成什么是webApis和APIDOM简介document对象获取DOM对象利用css选择器来获取DOM元素选择指定css选择器的所有元素其他获取DOM元素方法(了解)操作元素内容对象.innerText对象.innerHTML操作元素属性操作元素常用属性操作元素样式属性通过style属性操作......
  • WebAPI项目框架JWT权限验证
    JWT是什么?校验逻辑?授权过程?这里就不过多的阐述了,直接上代码在appsettings.json中配置jwt参数的值SecretKey必须大于16个字符1{2"Logging":{3"LogLevel":{4"Default":"Information",5"Microsoft.AspNetCore":"Warni......
  • 大学生HTML期末大作业——HTML+CSS+JavaScript运动网站(田径)
    HTML+CSS+JS【运动网站】网页设计期末课程大作业web前端开发技术web课程设计网页规划与设计......
  • 大学生HTML期末大作业——HTML+CSS+JavaScript购物商城(Oppo)
    HTML+CSS+JS【购物商城】网页设计期末课程大作业web前端开发技术web课程设计网页规划与设计......
  • Java实现登录验证 -- JWT令牌实现
    目录1.实现登录验证的引出原因2.JWT令牌2.1使用JWT令牌时2.2令牌的组成三.JWT令牌(token)生成和校验3.1引入JWT令牌的依赖3.2使用Jar包中提供的API来实现JWT令牌的生成和校验3.3使用JWT令牌验证登录1.实现登录验证的引出传统思路下:登录页面把用户名和密码交......
  • JavaScript 中删除数组元素
    在JavaScript中,没有像Java的ArrayList中的remove方法那样直接删除指定元素的方法,删除指定下标的数组元素可以通过几种方式实现方法一:使用 splice() 方法splice()方法可以在数组中添加或删除元素,并返回被删除的元素。letarr=[1,2,3,4,5];letindexToRemove......
  • JavaScript 学习教程:从入门到精通
    JavaScript学习教程:从入门到精通JavaScript是网页开发过程中不可或缺的一部分,无论你是初学者还是有一定基础的开发者,这篇教程将帮助你更深入地理解和运用JavaScript。本文将分为多个章节,涵盖JavaScript的基本概念、高级技术、常用库和框架,以及实际项目案例。目录Jav......
  • 【Python机器学习】模型评估与改进——带交叉验证的网格搜索
    虽然将数据划分为训练集、验证集、测试集的方法是可行的,也相对常用,但这种方法对数据的划分相当敏感,为了得到对泛化性能的更好估计,我们可以使用交叉验证来评估每种参数组合的性能,而不是仅将数据单次划分为训练集与验证集。代码表示如下:fromsklearn.svmimportSVCfromsklear......
  • 【JavaScript脚本宇宙】打造完美用户体验:六大模态库全解析
    从美观到高效:六大模态库实战指南前言随着现代Web开发的不断进步和用户体验要求的提升,模态窗口(Modal)已成为网页设计中不可或缺的一部分。模态窗提供了一种直观而有效的方式来展示重要信息、提示用户操作或承载交互内容。本文将全面介绍六大流行的模态库,包括BootstrapModal......