(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
}
相关推荐
Mahir0813 分钟前
Spring 循环依赖深度解密:从问题本质到三级缓存源码级解析
java·后端·spring·缓存·面试·循环依赖·三级缓存
杜子不疼.24 分钟前
【C++ AI 大模型接入 SDK】 - DeepSeek 模型接入(上)
开发语言·c++·chatgpt
RyFit1 小时前
SpringAI 常见问题及解决方案大全
java·ai
石山代码2 小时前
C++ 内存分区 堆区
java·开发语言·c++
心中有国也有家2 小时前
cann-recipes-infer:昇腾 NPU 推理的“菜谱集合”
经验分享·笔记·学习·算法
绝知此事2 小时前
【算法突围 01】线性结构与哈希表:后端开发的收纳术
java·数据结构·算法·面试·jdk·散列表
无风听海2 小时前
C# 隐式转换深度解析
java·开发语言·c#
碧海银沙音频科技研究院2 小时前
通话AEC与语音识别AEC的软硬回采链路
深度学习·算法·语音识别
一只大袋鼠3 小时前
Git 进阶(二):分支管理、暂存栈、远程仓库与多人协作
java·开发语言·git
csdn_aspnet3 小时前
Python 算法快闪 LeetCode 编号 70 - 爬楼梯
python·算法·leetcode·职场和发展