LeetCode.36.Valid Sudoku

19 篇文章 0 订阅
8 篇文章 0 订阅

原题链接:Valid Sudoku

题目内容:Determine if a Sudoku is valid, according to: Sudoku Puzzles - The Rules.

The Sudoku board could be partially filled, where empty cells are filled with the character ‘.’.

这里写图片描述
A partially filled sudoku which is valid.

Note:
A valid Sudoku board (partially filled) is not necessarily solvable. Only the filled cells need to be validated.
这里不需要验证是否有解,只要符合数独的规则就可以。


C++

class Solution {
public:
    bool isValidSudoku(vector<vector<char>>& board) {
        int i,j,k,l,row[10], col[10], grid[10];  
        if(board.size()!=9 || board[0].size()!=9)return false;  
        for(i=0;i<9;i++){
            memset(row,0,sizeof(row));
            for(j=0;j<9;j++){  
                if(board[i][j]=='.')continue;  
                if(board[i][j]<'0' || board[i][j]>'9')return false;  
                int num=board[i][j]-'0';  
                if(row[num])return false;  
                row[num]=true; 
            }  
        }  
        for(i=0;i<9;i++){
            memset(col,0,sizeof(col));  
            for(j=0;j<9;j++){  
                if(board[j][i]=='.')continue;  
                if(board[j][i]<'0' || board[j][i]>'9')return false;  
                int num=board[j][i]-'0';  
                if(col[num])return false;  
                col[num]=true;  
            }  
        }  
        for(i=0;i<3;i++){  
            for(j=0;j<3;j++){ 
                memset(grid,0,sizeof(grid));  
                for(k=i*3;k<i*3+3;k++){  
                    for(l=j*3;l<j*3+3;l++){  
                        if(board[k][l]=='.')continue;  
                        int num=board[k][l]-'0';  
                        if(grid[num])return false;  
                        grid[num]=true;  
                    }  
                }  
            }  
        }  
        return true;   
    }
};

python

class Solution(object):
    def isValidSudoku(self, board):
        """
        :type board: List[List[str]]
        :rtype: bool
        """
        seen = []
        for pos_r, row in enumerate(board):
            for pos_c, value in enumerate(row):
                if value != '.':
                    seen += [(value,pos_c),(pos_r,value),(pos_r/3,pos_c/3,value)]
        return len(seen) == len(set(seen))                    
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值