[力扣题解]37. 解数独

题目:37. 解数独

思路

回溯法

代码

cpp 复制代码
class Solution {
public:
    bool function(vector<vector<char>>& board)
    {
        int i, j;
        char k;
        for(i = 0; i < 9; i++)
        {
            for(j = 0; j < 9; j++)
            {
                // 为空
                if(board[i][j] == '.')
                {
                    for(k = '1'; k <= '9'; k++)
                    {
                        if(right(board, i, j, k))
                        {
                            board[i][j] = k;
                            if(function(board))
                            {
                                return true;
                            }
                            board[i][j] = '.';
                        }
                    }
                    return false;
                }
            }
        }
        // 都填满了
        return true;
    }

    // 检验合法性
    bool right(vector<vector<char>>& board, int row, int col, char num)
    {
        cout << "right start" << endl;
        int i, j;
        int start_i, start_j;
        // 行
        for(j = 0; j < 9; j++)
        {
            if(j != col && board[row][j] == num)
            {
                return false;
            }
        }
        // 列
        for(i = 0; i < 9; i++)
        {
            if(i != row && board[i][col] == num)
            {
                return false;
            }
        }
        // 九宫格
        start_i = (row / 3) * 3;
        start_j = (col / 3) * 3;
        for(i = start_i; i < start_i+3; i++)
        {
            for(j = start_j; j < start_j+3; j++)
            {
                if(!(i == row && j == col) && board[i][j] == num)
                {
                    return false;
                }
            }
        }
        return true;
    }

    void solveSudoku(vector<vector<char>>& board) {
        function(board);
    }
};

这里的回溯函数设计的很有趣,返回值为bool,所以没有特地写回溯结束的逻辑;

确定当前元素所在九宫格的位置时,用

cpp 复制代码
start_i = (row / 3) * 3;
start_j = (col / 3) * 3;

来表示九宫格的起点坐标;

function()什么时候return

  • 对于一个为空的格子,9个数字都试完还不对,就return false
  • 如果所有格子都填满了,并且没有检查出错误,就return true
  • 发现当这个格子填好之后,整个棋盘也填好了,就return true
相关推荐
历程里程碑4 分钟前
二叉树---二叉树的最大深度
大数据·数据结构·算法·elasticsearch·搜索引擎·全文检索·深度优先
自我意识的多元宇宙6 分钟前
树与二叉树--树的基本概念
数据结构·算法
吃着火锅x唱着歌7 分钟前
LeetCode 678.有效的括号字符串
算法·leetcode·职场和发展
音视频牛哥1 小时前
鸿蒙 NEXT RTSP/RTMP 播放器如何回调 RGB 数据并实现 AI 视觉算法分析
人工智能·算法·harmonyos·鸿蒙rtmp播放器·鸿蒙rtsp播放器·鸿蒙next rtsp播放器·鸿蒙next rtmp播放器
飞Link1 小时前
掌控 Agent 的时空法则:LangGraph Checkpoint (检查点) 机制深度实战
开发语言·python·算法
乐迪信息1 小时前
智慧港口中AI防爆摄像机的船舶越线识别功能
大数据·人工智能·物联网·算法·目标跟踪
F_D_Z1 小时前
扩散模型快速采样:从渐进蒸馏到并行推理
人工智能·算法·加速采样
睡一觉就好了。2 小时前
哈希表(一)
算法·散列表
輕華2 小时前
Word2Vec与CBOW算法实战:从词向量到上下文感知
人工智能·算法·word2vec
Matlab程序猿小助手2 小时前
【MATLAB源码-第315期】基于matlab的䲟鱼优化算法(ROA)无人机三维路径规划,输出做短路径图和适应度曲线.
开发语言·算法·matlab