(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
}
相关推荐
handsome_sai2 小时前
【Java 线程池】记录
java
大学生资源网3 小时前
基于springboot的唐史文化管理系统的设计与实现源码(java毕业设计源码+文档)
java·spring boot·课程设计
leiming63 小时前
C++ vector容器
开发语言·c++·算法
guslegend3 小时前
SpringSecurity源码剖析
java
roman_日积跬步-终至千里4 小时前
【人工智能导论】02-搜索-高级搜索策略探索篇:从约束满足到博弈搜索
java·前端·人工智能
Xの哲學4 小时前
Linux流量控制: 内核队列的深度剖析
linux·服务器·算法·架构·边缘计算
大学生资源网4 小时前
java毕业设计之儿童福利院管理系统的设计与实现(源码+)
java·开发语言·spring boot·mysql·毕业设计·源码·课程设计
JasmineWr4 小时前
JVM栈空间的使用和优化
java·开发语言
Hello.Reader4 小时前
Flink SQL DELETE 语句批模式行级删除、连接器能力要求与实战避坑(含 Java 示例)
java·sql·flink
爱笑的眼睛115 小时前
从 Seq2Seq 到 Transformer++:深度解构与自构建现代机器翻译核心组件
java·人工智能·python·ai