力扣-有效的数独

请你判断一个 9 x 9 的数独是否有效。只需要 根据以下规则 ,验证已经填入的数字是否有效即可。

  1. 数字 1-9 在每一行只能出现一次。
  2. 数字 1-9 在每一列只能出现一次。
  3. 数字 1-9 在每一个以粗实线分隔的 3x3 宫内只能出现一次。(请参考示例图)

注意:

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

大致思路:

题目并不需要我们求出每个格子中具体的数,而是判断输入的数字是否符合数独的规则,所以我们只需要判断每一行中,每一列和每个九宫格中是否存在重复的数字即可。如果存在重复的数返回 false,否则返回 true。

重复数的判断:

1.遍历二维数组borad,对每个元素判断其是否符合条件。

2.用大小为10的数组 hash 保存数字出现的次数。

3.把输入的数字转化为整形的数字并作为下标访问hash 数组,当hash中某个元素出现次数 >=1,返回 false,3种条件都判断完时返回 true。

bool Isvalid(char**board,int x,int y)
{int i,j;int s;int hashcol[10]={0};//判断一列中出现元素的个数int hashrol[10]={0};//判读一行中出现元素的个数int hashmagic[10]={0};//九宫格中出现元素的个数//行for(j=0;j<9;j++){if(board[x][j]!='.')//只判断输入的数,空格无需判断{s=board[x][j]-'0';//字符数字转化为整形数字if(hashrol[s]>=1)//出现重复的数return false;hashrol[s]++;}}//列for(i=0;i<9;i++){if(board[i][y]!='.'){s=board[i][y]-'0';//if(hashcol[s]>=1)return false;hashcol[s]++;}}//九宫格int startx=x/3*3;//每个九宫格的起始坐标int starty=y/3*3;for(i=startx;i<startx+3;i++){for(j=starty;j<starty+3;j++){if(board[i][j]!='.'){s=board[i][j]-'0';if(hashmagic[s]>=1)return false;hashmagic[s]++;}}}return true;
}
bool isValidSudoku(char** board, int boardSize, int* boardColSize) {for(int i=0;i<9;i++){for(int j=0;j<9;j++){if(board[i][j]!='.'){if(!Isvalid(board,i,j))return false;}}}return true;
}

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

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

相关文章

【竞赛指导】五一杯、电工杯、东三省等数学建模比赛招收学员

老师介绍 讲师1&#xff1a;985研究生&#xff0c;获得过研究生数学建模竞赛国二&#xff0c;研究生数学建模竞赛国三&#xff0c;东三省数学建模一等奖两次&#xff0c;本科组国赛数学建模省一两次。有多篇SCI论文发表经验&#xff0c;有带学生经验&#xff0c;擅长各类运筹、…

(三十一)第 5 章 数组和广义表(稀疏矩阵的三元组行逻辑链接的顺序存储表示实现)

1. 背景说明 2. 示例代码 1)errorRecord.h // 记录错误宏定义头文件#ifndef ERROR_RECORD_H #define ERROR_RECORD_H#include <stdio.h> #include <string.h> #include <stdint.h>// 从文件路径中提取文件名 #define FILE_NAME(X) strrchr(X, \\) ? strrch…

AI 工具合集

以下工具来源于互联网&#xff0c;可能会失效&#xff0c;请参考使用 网红工具 名称链接说明GPT-4https://chat.openai.com/ 需要梯子&#xff0c;需要付费。功能最强大的聊天机 器人。 文心一言https://yiyan.baidu.com/welcome 国内版 GPT&#xff0c;需要申请账号。回答问…

将子进程(exe)界面嵌入到主进程(另一exe)界面中——Qt

前言 近期项目中,要将子进程界面嵌入到主进程中,双方都是自己开发的,之前有过研究,曾经写过一篇文章 将外部exe嵌入到界面中(Windows)——Qt_startf_useshowwindow-CSDN博客,如今发现不好用,界面是嵌入了,但是并没有按照要求的大小展示,通过了几种方法(布局、绝对位…

flume配置

flume配置 下载并解压到指定文件夹 tar -zxvf apache-flume-1.11.0-bin.tar.gz -C /opt/software/进入Flume安装目录的conf目录&#xff0c;将flume-env.sh.template重命名为flume-env.sh&#xff0c;Java安装目录添加至flume-env.sh文件末尾。 # 更改文件名称 mv flume-env.…

最好用的电脑监控软件,电脑监控软件怎么监控员工

电脑监控软件是一种专为跟踪和记录计算机使用情况而设计的应用程序&#xff0c;主要用于提升企业内部的信息安全、提高工作效率及监管员工行为。这些软件通常通过以下几种方式实现监控功能&#xff1a; 实时屏幕监控&#xff1a; 软件能够实时显示被监控电脑的屏幕画面&#x…

数据分析:扩增子分析(qiime2平台全流程分析)

Amplicon sequencing analysis pipeline through qiime2 platform qiime2是扩增子数据分析的最佳平台之一&#xff0c;其提供了大量从原始data到统计分析的插件&#xff0c;尤其是它的可重复分析且可扩展插件的理念使得其成为扩增子分析首选的平台。 Platform qiime2是扩增子…

【工作实践-11】关于uniapp切换账号登录失败问题

遇到问题&#xff1a;在使用uniapp写的程序中&#xff0c;第一次打开程序登录(账号密码正确)&#xff0c;调用登录接口&#xff0c;没有任何问题&#xff0c;正常登录&#xff1b;退出登陆后&#xff0c;输入不同的账号密码(账号密码均正确)&#xff0c;调用登录接口提示登陆失…

Airmail 5 for Mac:高效电子邮件管理软件

Airmail 5 for Mac作为一款功能强大的电子邮件客户端软件&#xff0c;为Mac用户带来了全新的邮件管理体验。其高效、直观的操作界面&#xff0c;使得用户可以轻松管理各类邮件&#xff0c;提升工作效率。 Airmail 5 for Mac v5.7.4中文激活版 首先&#xff0c;Airmail 5支持多个…

CSS接触

标签&#xff1a; 块标签&#xff0c;用来给网页分块 默认占一行<div></div> 无意义标签 <span></span> 背景颜色 background-color:颜色 字体颜色color: 颜色; 使用css&#xff1a; 一、使用css- 内嵌样式&#xff1a; 1. 在h…

若依前后端部署系统--详细附图

一、后端部署 1、在ruoyi项目的Maven中的生命周期下双击package.bat打包Web工程&#xff0c;生成jar包文件。 提示打包成功 2、多模块版本会生成在ruoyi/ruoyi-admin模块下target文件夹,我们打开目录ruoyi-admin/taget&#xff0c;打开cmd&#xff0c;运行java -jar jar包名称…

Windows Server 评估版转换(升级)为完整版

临时方法 获取 Windows Server 的剩余宽限期 Slmgr /dliWindows Server免费试用期可以使用以下命令合法延长5次&#xff0c;共180天&#xff1a; slmgr /rearm这意味着所评估的 Windows Server 的最长可用时间为 3 年 ( 180 days * 6)。 试用期到期后&#xff0c;Windows S…

为什么有些3D模型导入总是渲染不出来?---模大狮模型网

在使用3D建模软件时&#xff0c;有时候会遇到一些导入模型后无法正确渲染的问题&#xff0c;这给用户带来了不便和困扰。本文将探讨一些可能导致3D模型无法渲染的原因&#xff0c;并提供解决方案&#xff0c;帮助您顺利渲染模型。 一、文件格式不兼容某些3D建模软件只支持特定的…

用asio::tcp通信的服务端

tcp服务端dll TcpServer.h // TcpServer.h #ifndef TCPSERVER_H #define TCPSERVER_H#include <asio.hpp> #include <functional>class TcpServer

C语言仿写strlen函数以及编程常见的错误、以及,打印菱形、空瓶换水、水仙花数、反转字符串等小案例

文章目录 前言一、仿写strlen函数二、编程常见的错误1. 编译型错误(语法错误)2. 链接型错误(链接期间)3. 运行时错误(最难找) 三、小案例1. 打印菱形2. 两个空瓶换一瓶水的实现3. 打印 aaaaaaaaaaaaaaa......的和4. 打印0-100000"水仙花数"5. 反转字符串 总结 前言 …

设计模式|原型模式(Prototype Pattern)

文章目录 什么是原型模式结构优缺点优点缺点举例代码示例原型模式vs复制(copy)什么是原型模式 原型模式(Prototype Pattern)是一种创建型设计模式,其核心思想是通过复制现有对象来创建新对象,而无需显式地指定它们的类。这种模式通常用于当对象的创建成本较高,或者对象…

共赢闽企数字生态,2024纷享销客福建生态伙伴会圆满成功

4月26日&#xff0c;2024纷享销客福建生态伙伴会在厦门顺利举行&#xff0c;大会以“共赢闽企数字生态&#xff0c;共绘数智发展蓝图“为主题&#xff0c;特邀纷享销客创始人&CEO罗旭、建发旅游集团信息中心总经理高勇、金蝶&#xff08;厦门&#xff09;市场总监王鹭鸣、纷…

一加Ace3/12/Ace2pro手机ColorOS14刷KernelSU内核ROOT-解决无限重启变砖

一加Ace3/一加12/一加11等手机升级了安卓14底层&#xff0c;并且ColorOS版本也更新到了14版本界面和功能都比之前的系统表现更加优秀&#xff0c;但刷机方面&#xff0c;相对之前存在一些差异&#xff0c;特别是KernelSU内核级别root权限&#xff0c;不再支持一键刷入KernelSU通…

多模态视觉大模型(1):大模型的架构

文章目录 1.多模态大模型介绍1.1 多模态定义1.2 多模态大模型的类型1.3 GPT-4V 效果展示2.多模态网络架构1.多模态大模型介绍 1.1 多模态定义 多模态指的是输入数据的类型,它可以是文本、视频、音频等不同的模态形式,包括各种表格,json,图像以及各种传感器采的数据 在深度学…

七、OSPF特殊区域及其特性

目录 OSPF区域分类 hello报文中option字段 1.末节区域&#xff08;Stub区域&#xff09; 2.完全末节区域&#xff08;Toally Stub区域&#xff09; 3.七类LSA 4.非完全末节区域&#xff08;NSSA区域&#xff09; 5.完全非完全末节区域&#xff08;Toally NSSA区域&#…