前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Leetcode: Valid Sudoku

Leetcode: Valid Sudoku

作者头像
卡尔曼和玻尔兹曼谁曼
发布2019-01-22 17:35:54
4410
发布2019-01-22 17:35:54
举报

题目: 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 ‘.’.

Sudoku规则:

在一个9*9的区域内, 每行1-9出现且只出现一次, 每列1-9出现且只出现一次, 在9个子3*3的区域内1-9出现且只出现一次。

C++参考代码:

代码语言:javascript
复制
class Solution
{
public:
    bool isValidSudoku(vector<vector<char> > &board)
    {
        //row和column分别记录行和列中元素出现的次数
        int row[9], column[9];

        //判断行和列是否满足要求
        for (int i = 0; i < 9; i++)
        {
            //将row和column赋值为0
            memset(row, 0, sizeof(int) * 9);
            memset(column, 0, sizeof(int) * 9);
            for (int j = 0; j < 9; j++)
            {
                //对行的判断
                if (board[i][j] != '.')
                {
                    //board[i][j] - '1'是计算board[i][j]这个数在row中对应的下标
                    //如果board[i][j]这个数字出现的次数大于1次,即row[board[i][j] - '1'] > 0则返回false
                    if (row[board[i][j] - '1'] > 0) return false;
                    else row[board[i][j] - '1']++;
                }
                //对列的判断(同理)
                if (board[j][i] != '.')
                {
                    if (column[board[j][i] - '1'] > 0) return false;
                    else column[board[j][i] - '1']++;
                }
            }
        }

        //判断3*3的区域是否满足要求
        int block[9];
        //外层的两个for循环控制对block的移动遍历
        for (int i = 0; i < 9; i += 3)
        {
            for (int j = 0; j < 9; j += 3)
            {
                memset(block, 0, sizeof(int) * 9);
                //内层的两个for循环控制对block内部的数据进行遍历判断
                for (int m = 0; m < 3; m++)
                {
                    for (int n = 0; n < 3; n++)
                    {
                        //判断方法和对行列的判断方法一样
                        if (board[i + m][j + n] != '.')
                        {
                            if (block[board[i + m][j + n] - '1'] > 0) return false;
                            else block[board[i + m][j + n] - '1']++;
                        }
                    }
                }
            }
        }
        return true;
    }
};
本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2015年03月15日,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档