zoukankan      html  css  js  c++  java
  • [LeetCode] 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.

    方法:不必把空格都填好,只需检测给出的已经填好的数是否在行中、列中、小区域中重复,so easy,并不是检测它是否能填满哦

    方法1:

    class Solution {
    public:
        bool isValidSudoku(vector<vector<char> > &board) {  
            // Note: The Solution object is instantiated only once.   
            vector<int> row(9,0);
            vector<int> col(9,0);
            vector<int> tmp(9,0); 
            for(int i = 0; i < 9; i++)  
            {  
                row = tmp;
                col = tmp;
                for(int j = 0; j < 9; j++)  
                {  
                    if(board[i][j] != '.')  
                    {  
                        if(row[board[i][j]-'1'] > 0)return false;  
                        else row[board[i][j]-'1']++;  
                    }  
                    if(board[j][i] != '.')  
                    {  
                        if(col[board[j][i]-'1'] > 0)return false;  
                        else col[board[j][i]-'1']++;  
                    }  
                }  
            }  
    
            for(int i = 0; i < 9; i+=3)  
                for(int j = 0; j < 9; j+=3)  
                {  
                    row = tmp;
                    for(int a = 0; a < 3; a++)  
                        for(int b= 0; b < 3; b++)  
                            if(board[i+a][j+b] != '.')  
                            {  
                                if(row[board[i+a][j+b]-'1']>0)return false;  
                                else row[board[i+a][j+b]-'1']++;  
                            }  
                }  
                return true;  
        }  
    };

    方法2:

    class Solution {
    public:
        bool isValidSudoku(vector<vector<char> > &board) {
            // Start typing your C/C++ solution below
            // DO NOT write int main() function
            if(board.size()<9 || board[0].size()<9)
               return false;
               
        vector<bool> tmp(9,false);
            vector<vector<bool> > r(9,tmp);
            vector<vector<bool> > c(r);
        vector<vector<bool> > b(r);
            
            for(int i=0; i<9; i++)
               for(int j=0; j<9; j++)
               {
                   if(board[i][j]=='.')
                     continue;
                   int a = (i/3)*3 + j/3;
                   int number = board[i][j]-'1';
                   if(r[i][number] || c[j][number] || b[a][number])
                       return false;
                   r[i][number] = c[j][number] = b[a][number] = 1;
               }
            return true;
        }
    };

    方法3:

    class Solution {
    public:
        bool isValidSudoku(vector<vector<char> > &board) {
            int row,row2;
            int col,col2;
            int sqr,sqr2;
            int a,b,c;
    
            for(int i=0;i<9;i++){
                row=0;row2 = 0;
                col=0;col2 = 0;
                sqr = 0;sqr2 =0;
                for(int j=0;j<9;j++){
                   a = board[i][j] - '0';
                   b = board[j][i] -  '0';
                   c = board[3*(i%3)+j/3][3*(i/3)+j%3] - '0';
                   if(a>0) row2 ^= 1<< a;
                   if(b>0) col2 ^= 1<< b;
                   if(c>0) sqr2 ^= 1<< c;
    
                   if(row2 < row || col2<col || sqr2<sqr)
                       return false;
                   row = row2;
                   col = col2;
                   sqr = sqr2;
                }
            }
            return true;
        }
    };
  • 相关阅读:
    【安全运维】在Windows平台利用sysmon进行安全分析
    【渗透测试】利用分块传输绕安全狗
    【渗透测试】如何获取目标网站真实IP
    【渗透测试】渗透测试常用在线工具
    【读书笔记】《互联网企业安全建设高级指南》6-17
    【安全运维】linux安全加固项目
    【安全运维】初识osquery
    【渗透测试】使用隧道模式访问目标数据库
    【企业安全】使用文件hash进行威胁分析
    【编程开发】python学习-判断是否是私网IP地址
  • 原文地址:https://www.cnblogs.com/Xylophone/p/3936872.html
Copyright © 2011-2022 走看看