数独游戏——数模处理(MATLAB整数规划)

本文介绍了使用MATLAB通过整数规划解决数独问题的方法。首先,文章阐述了数独问题的数学模型,将9x9的数独转化为9x9x9的三维矩阵,并设置了相应的约束条件。接着,详细讲解了求解思路,特别是系数矩阵Aeq的构造。最后,展示了主程序shudu.m、转置函数trans.m和显示函数showShudu.m的源代码。
摘要由CSDN通过智能技术生成

一、问题描述

  数独是源自18世纪瑞士的一种数学游戏,盘面是个九宫,每一宫又分为九个小格。在这八十一格中根据已知数字和解题条件,利用逻辑和推理,在其他的空格上填入1-9的数字,使1-9中的每个数字在每一行、每一列和每一宫中都只出现一次。

二、模型建立

  将 9 × 9 9\times9 9×9 的数独矩阵转化为 9 × 9 × 9 9\times9\times9 9×9×9 的三维矩阵 ,三维矩阵中每一个元素的值为0或1。例如,若原数独矩阵的第一行第二列的数字为7,则三维矩阵第7层的对应位置为1,其它层该位置皆为0,总共个 9 × 9 × 9 9\times9\times9 9×9×9 变量,用 X ( i , j , k ) X(i,j,k) X(i,j,k) 表示第 k k k 层矩阵的第 i i i 行第 j j j 列的元素。

  约束条件:

  1. 9层矩阵的同一位置只可以出现一个1:
    ∑ k = 1 9 X ( i , j , k ) = 1 , i = 1 , 2 , ⋯   , 9 , j = 1 , 2 , ⋯   , 9 \sum_{k=1}^9X(i,j,k)=1, i=1,2,\cdots,9,j=1,2,\cdots,9 k=19X(i,j,k)=1,i=1,2,,9,j=1,2,,9

  2. 任何一层的任何一行只能有一个1:
    ∑ j = 1 9 X ( i , j , k ) = 1 , i = 1 , 2 , ⋯   , 9 , k = 1 , 2 , ⋯   , 9 \sum_{j=1}^9X(i,j,k)=1, i=1,2,\cdots,9,k=1,2,\cdots,9 j=19X(i,j,k)=1,i=1,2,,9,k=1,2,,9

  3. 任何一层的任何一列只能有一个1:
    ∑ i = 1 9 X ( i , j , k ) = 1 , j = 1 , 2 , ⋯   , 9 , k = 1 , 2 , ⋯   , 9 \sum_{i=1}^9X(i,j,k)=1, j=1,2,\cdots,9,k=1,2,\cdots,9 i=19X(i,j,k)=1,j

  • 43
    点赞
  • 142
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值