(LeetCode 每日一题) 36. 有效的数独 (数组、哈希表)

题目:36. 有效的数独


思路:哈希表+数组,时间复杂度0(n^2)。

用哈希表来维护数组元素在每行、每列、和3x3宫格内的分布情况。

C++版本:

cpp 复制代码
class Solution {
public:
    bool isValidSudoku(vector<vector<char>>& board) {
        vector<vector<bool>> row(9,vector<bool>(9,false));
        vector<vector<bool>> col(9,vector<bool>(9,false));
        bool single_range[3][3][9];
        memset(single_range,false,sizeof single_range);

        for(int i=0;i<9;i++){
            for(int j=0;j<9;j++){
                char c=board[i][j];
                if(c=='.') continue;
                int t=c-'1';
                if(row[i][t]==true || col[j][t]==true || single_range[i/3][j/3][t]==true){
                    return false;
                }
                row[i][t]=true;
                col[j][t]=true;
                single_range[i/3][j/3][t]=true;
            }
        }
        return true;
    }
};

JAVA版本:

java 复制代码
class Solution {
    public boolean isValidSudoku(char[][] board) {
        boolean[][] row=new boolean[9][9];
        boolean[][] col=new boolean[9][9];
        boolean[][][] single_range=new boolean[3][3][9];

        for(int i=0;i<9;i++){
            for(int j=0;j<9;j++){
                char c=board[i][j];
                if(c=='.') continue;
                int t=c-'1';
                if(row[i][t]==true || col[j][t]==true || single_range[i/3][j/3][t]==true){
                    return false;
                }
                row[i][t]=true;
                col[j][t]=true;
                single_range[i/3][j/3][t]=true;
            }
        }
        return true;
    }
}

GO版本:

go 复制代码
func isValidSudoku(board [][]byte) bool {
    row:=[9][9]bool{}
    col:=[9][9]bool{}
    single_range:=[3][3][9]bool{}

    for i:=0;i<9;i++{
        for j:=0;j<9;j++{
            c:=board[i][j]
            if c=='.' {
                continue
            }
            t:=c-'1';
            if row[i][t]==true || col[j][t]==true || single_range[i/3][j/3][t]==true {
                return false
            }
            row[i][t]=true
            col[j][t]=true
            single_range[i/3][j/3][t]=true
        }
    }
    return true
}
相关推荐
新知图书35 分钟前
JMeter的定时器
java·jvm·jmeter
智星云算力38 分钟前
从保存到加载Docker镜像文件操作全图解
java·spring cloud·eureka
邂逅星河浪漫2 小时前
【Spring AI】Ollama大模型-智能对话实现+项目实战(Spring Boot + Vue)
java·人工智能·spring boot·vue·prompt·agent·ollama
KWTXX2 小时前
【国二】C语言-部分典型真题
java·c语言·算法
Q_Q5110082852 小时前
python+springboot毕业季旅游一站式定制服务系统
java·spring boot·python·django·flask·node.js·旅游
杨杨杨大侠2 小时前
探索 Event 框架实战指南:微服务系统中的事件驱动通信:
java·spring boot·微服务·云原生·架构·系统架构
波波烤鸭2 小时前
Tomcat 性能优化与高并发调优
java·tomcat
phdsky2 小时前
【设计模式】中介者模式
c++·设计模式·中介者模式
摩羯座-185690305943 小时前
VVIC 平台商品详情接口高效调用方案:从签名验证到数据解析全流程
java·前端·数据库·爬虫·python
lucialeia3 小时前
leetcode (4)
算法·leetcode