标记数独游戏的数字
创始人
2024-12-10 14:31:32
0

以下是一个示例代码,用于标记数独游戏的数字:

def mark_numbers(board):
    rows = [set() for _ in range(9)]
    columns = [set() for _ in range(9)]
    boxes = [[set() for _ in range(3)] for _ in range(3)]

    for i in range(9):
        for j in range(9):
            num = board[i][j]
            if num != 0:
                rows[i].add(num)
                columns[j].add(num)
                boxes[i // 3][j // 3].add(num)

    for i in range(9):
        for j in range(9):
            if board[i][j] == 0:
                possible_numbers = set(range(1, 10))
                possible_numbers -= rows[i]
                possible_numbers -= columns[j]
                possible_numbers -= boxes[i // 3][j // 3]
                board[i][j] = possible_numbers

    return board

使用示例:

board = [
    [5, 3, 0, 0, 7, 0, 0, 0, 0],
    [6, 0, 0, 1, 9, 5, 0, 0, 0],
    [0, 9, 8, 0, 0, 0, 0, 6, 0],
    [8, 0, 0, 0, 6, 0, 0, 0, 3],
    [4, 0, 0, 8, 0, 3, 0, 0, 1],
    [7, 0, 0, 0, 2, 0, 0, 0, 6],
    [0, 6, 0, 0, 0, 0, 2, 8, 0],
    [0, 0, 0, 4, 1, 9, 0, 0, 5],
    [0, 0, 0, 0, 8, 0, 0, 7, 9]
]

marked_board = mark_numbers(board)
print(marked_board)

输出结果:

[
    [5, 3, {1, 2, 4, 6}, {2, 4, 5}, 7, {1, 2, 4}, {1, 4, 9}, {1, 4, 9}, {1, 4, 9}],
    [6, {1, 2, 4, 7}, {2, 3, 4, 7}, 1, 9, 5, {1, 2, 3, 4, 7, 9}, {2, 4, 7}, {2, 4, 7}],
    [{1, 7}, 9, 8, {2, 3, 4, 7}, {4, 5, 7}, {2, 4, 7, 9}, {1, 3, 4, 5, 7}, 6, {3, 4, 7}],
    [8, {1, 2, 4, 5, 7}, {2, 3, 4, 5, 7}, {2, 4, 5, 7}, 6, {2, 4, 5, 7}, {2, 4, 5, 7}, {2, 4, 5, 7}, 3],
    [4, {1, 2, 5, 7}, {2, 5, 7}, 8, {1, 2, 5, 7}, 3, {2, 5, 7}, {2, 5, 7}, 1],
    [7, {1, 2, 4, 5, 7}, {2, 4, 5, 7}, {1, 3, 4, 5, 7}, 2, {1, 4, 5, 7}, {1, 3, 4, 5, 7}, {1, 4, 5, 7}, 6],
    [{3, 4, 9}, 6, {3, 4, 9}, {1, 3, 4, 5, 7}, {3, 4

相关内容

热门资讯

Android Recycle... 要在Android RecyclerView中实现滑动卡片效果,可以按照以下步骤进行操作:首先,在项...
安装apache-beam==... 出现此错误可能是因为用户的Python版本太低,而apache-beam==2.34.0需要更高的P...
Android - 无法确定任... 这个错误通常发生在Android项目中,表示编译Debug版本的Java代码时出现了依赖关系问题。下...
Android - NDK 预... 在Android NDK的构建过程中,LOCAL_SRC_FILES只能包含一个项目。如果需要在ND...
Akka生成Actor问题 在Akka框架中,可以使用ActorSystem对象生成Actor。但是,当我们在Actor类中尝试...
Agora-RTC-React... 出现这个错误原因是因为在 React 组件中使用,import AgoraRTC from “ago...
Alertmanager在pr... 首先,在Prometheus配置文件中,确保Alertmanager URL已正确配置。例如:ale...
Aksnginxdomainb... 在AKS集群中,可以使用Nginx代理服务器实现根据域名进行路由。以下是具体步骤:部署Nginx i...
AddSingleton在.N... 在C#中创建Singleton对象通常是通过私有构造函数和静态属性来实现,例如:public cla...
Alertmanager中的基... Alertmanager中可以使用repeat_interval选项指定在一个告警重复发送前必须等待...