递归法解决数独sudoku,附python实现代码

本文介绍了一种使用递归算法解决数独问题的Python实现。通过检查行、列和九宫格中已有的数字,递归填充空白单元格。当无法填充时进行回溯,直至找到唯一解决方案。代码示例展示了如何初始化和执行递归深度优先搜索(DFS)。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

递归法解决数独sudoku,python实现

定义

数独是源自18世纪瑞士的一种数学游戏。是一种运用纸、笔进行演算的逻辑游戏。玩家需要根据9×9盘面上的已知数字,推理出所有剩余空格的数字,并满足每一行、每一列、每一个粗线宫(3*3)内的数字均含1-9,不重复 。
数独盘面是个九宫,每一宫又分为九个小格。在这八十一格中给出一定的已知数字和解题条件,利用逻辑和推理,在其他的空格上填入1-9的数字。使1-9每个数字在每一行、每一列和每一宫中都只出现一次,所以又称“九宫格”。

算法思想

利用递归的思想,对于sudoku数组,每一个数字判断当前行、列、九宫中已经出现的数字,从未出现的数字中顺序选择一个填入空白处。如果发现某一个空格没有可填数字,则进行回溯。
初始化:
sudoku数组9x9数组,初始化为0
tmp数组1x9数组,初始化为0

代码

# -*- coding: utf-8 -*-
# @Time    : 2022/4/30 15:45
# @Author  : kunkun
# @File    : algorithm1.py
# ------------------------------
# 解决数独算法1
# 算法主要思路,递归寻找可以填入的值,找不到则回溯

import numpy as np

sudoku = np.zeros((9, 9), dtype=np.int32)


def dfs(x, y):
    if x == 9:  # 找到答案,返回True
        return 1
    if sudoku[x][y] != 0:  # 当前位置已经有值
        if y + 1 <= 8:
            return dfs(x, y + 1)
        else:
            return dfs(x + 1, 0)
    tmp = np.zeros(9, np.int32)  
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值