(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
}
相关推荐
流水武qin2 分钟前
SpringAI多模态的基本使用
java·spring boot·spring·ai
做怪小疯子7 分钟前
Leetcode刷题——8.重叠区间
算法·leetcode·职场和发展
共享家95278 分钟前
Java入门(多态)
java·开发语言
2401_857865239 分钟前
C++模块接口设计
开发语言·c++·算法
add45a19 分钟前
嵌入式C++低功耗设计
开发语言·c++·算法
DeepModel22 分钟前
【概率分布】指数分布(Exponential Distribution)原理、推导与实战
python·算法·概率论
毕设源码-赖学姐22 分钟前
【开题答辩全过程】以 基于Java的婚礼策划平台的设计与实现为例,包含答辩的问题和答案
java·开发语言
_饭团26 分钟前
指针核心知识:5篇系统梳理3
c语言·数据结构·算法·leetcode·面试·学习方法·改行学it
2401_8747325328 分钟前
C++中的状态模式
开发语言·c++·算法
BB学长28 分钟前
LBM vs FVM:谁才是 CFD 的未来?
人工智能·算法·机器学习