- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在尝试使用 Python 线性优化库 Pulp 来解决 killer 数独问题。
https://en.wikipedia.org/wiki/Killer_sudoku
这是我迄今为止的尝试,添加了每行加起来必须等于 45 的约束。
import pulp
prob = pulp.LpProblem("Sudoku Problem")
prob += 0, "Arbitrary Objective Function"
# 9 by 9 grid of 'choices', integers between 1-9
choices = pulp.LpVariable.dicts(
"Choice", (range(9), range(9)), cat="Integer", lowBound=1, upBound=9)
# identify puzzle rows that must have only 1 of every value
row_groups = [[(i, j) for i in range(9)] for j in range(9)]
# Seems to work, make every row add up 45
for distinct_group in row_groups:
for i, j in distinct_group:
distinct_group_constraint = [choices[i][j] for i, j in distinct_group]
prob += pulp.lpSum(distinct_group_constraint) == 45
# ... Code to add additional constraints for columns, boxes and 'cages'. Excluded for brevity.
prob.solve()
问题是我正在努力添加更严格的约束,即一行中的每个值必须不同。例如,如果一行具有这些值
[1,9,1,9,1,9,1,9,5]
它将通过上面的约束,但不会是有效的数独行,因为每个值都不是唯一的。
下面是我尝试添加更严格的约束,它似乎不起作用,因为问题没有解决
for n in range(1, 10):
for distinct_group in row_groups:
for i, j in distinct_group:
distinct_group_constraint = [choices[i][j] == n for i, j in distinct_group]
prob += pulp.lpSum(distinct_group_constraint) == 1
我在网上看到了几个例子,通过将这种优化重新定义为二进制标志的 9x9x9 选择,而不是整数 1-9 选择的 9x9 优化来解决这个问题。问题是,我发现很难看出如何在 9x9x9 的情况下轻松检查“笼子”的总和,而这在 9x9 的情况下非常简单。
这是“非 killer ”数独的 9x9x9 设置示例。 https://github.com/coin-or/pulp/blob/master/examples/Sudoku1.py
# cells (0,0) and (0,1) must sum to 8
cage_constraints = [(8, [[0, 0], [0, 1]])]
for target, cells in cage_constraints:
cage_cells_constraint = [choices[i][j] for i, j in cells]
prob += pulp.lpSum(cage_cells_constraint) == target
我希望 (a) 找到一种方法来添加更严格的约束,即在 9x9 设置中任何选择都不能重复,或者 (b) 一种方法来轻松添加 9x9x9 情况下笼子“总和”的约束。如果您想要测试整个笼子约束列表,这里是此谜题中的笼子约束列表。
CAGE_CONSTRAINTS = [
(8, [[0, 0], [0, 1]]),
(9, [[0, 6], [0, 7]]),
(8, [[0, 2], [1, 2]]),
(12, [[0, 3], [0, 4], [1, 3]]),
(15, [[0, 5], [1, 5], [2, 5]]),
(19, [[1, 6], [1, 7], [2, 7]]),
(16, [[0, 8], [1, 8], [2, 8]]),
(14, [[1, 0], [1, 1], [2, 0]]),
(15, [[2, 1], [2, 2]]),
(10, [[2, 3], [3, 3]]),
(12, [[1, 4], [2, 4]]),
(7, [[2, 6], [3, 6]]),
(24, [[3, 0], [3, 1], [4, 1]]),
(17, [[3, 7], [3, 8], [4, 8]]),
(8, [[3, 2], [4, 2]]),
(12, [[4, 3], [5, 3]]),
(19, [[3, 4], [4, 4], [5, 4]]),
(4, [[3, 5], [4, 5]]),
(15, [[4, 6], [5, 6]]),
(12, [[4, 0], [5, 0], [5, 1]]),
(7, [[4, 7], [5, 7], [5, 8]]),
(8, [[5, 2], [6, 2]]),
(10, [[6, 4], [7, 4]]),
(14, [[5, 5], [6, 5]]),
(12, [[6, 6], [6, 7]]),
(18, [[6, 8], [7, 7], [7, 8]]),
(15, [[6, 0], [7, 0], [8, 0]]),
(13, [[6, 1], [7, 1], [7, 2]]),
(12, [[6, 3], [7, 3], [8, 3]]),
(15, [[7, 5], [8, 4], [8, 5]]),
(7, [[7, 6], [8, 6]]),
(10, [[8, 1], [8, 2]]),
(8, [[8, 7], [8, 8]]),
]
https://www.dailykillersudoku.com/search?dt=2020-02-15
这是解决方案 https://www.dailykillersudoku.com/pdfs/19664.solution.pdf
编辑 - 如果我尝试使用二元选择更改为 9x9x9 问题,我得到的结果与我想要的笼子约束不匹配。这是一个片段。
choices = pulp.LpVariable.dicts(
"Choice", (range(9), range(9), range(1, 10),), cat="Binary"
)
# add constraints that only one choice for each 'distinct_group'
for n in range(1, 10):
for distinct_group in distinct_groups:
for i, j in distinct_group:
distinct_group_constraint = [choices[i][j][n] for i, j in
distinct_group]
prob += pulp.lpSum(distinct_group_constraint) == 1
# add constraints that cells in cages must equal 'cage_total'
for target, cells in CAGE_CONSTRAINTS:
cage_cells_constraint = [
choices[i][j][n] * n for i, j in cells for n in range(1, 10)
]
prob += pulp.lpSum(cage_cells_constraint) == target
这是完整的示例 https://gist.github.com/olicairns/d8e222526b87a62b2e175837b452c24a
最佳答案
我建议使用二进制变量 - 根据您找到的示例。它可能看起来像是更多的变量,但据我所知,使用较少数量的整数变量根本不会帮助解决问题 - 用于解决整数变量问题的“分支定界”算法意味着它是就像拥有更多的二进制变量一样低效(更熟悉这一点的人可能能够纠正我)。
所以回答你问题的后半部分:
(b) a way to easily add constraints of the 'sum' of cages in the 9x9x9 case.
这非常简单 - 您只需通过每个变量代表的索引来计算单元格的二进制变量的和积。
如果您已经开发了假设您选择的变量(9x9 整数变量)的所有代码,则可以添加 9x9x9 二进制变量,然后约束您的 9x9 整数变量(现在将是辅助变量),如下所示:
for i in range(1, 10):
for j in range(1, 10):
pulp += choices[i][j] == pulp.lpSum([binary_choices[i][j][k]*k for k in range(1,10)])
您现在拥有两组变量 - 一组二进制变量和一组整数变量,这些变量与等式约束链接以按要求运行。如果您想避免所有辅助变量,那么您只需在当前使用整数变量的任何地方将和积替换为上述索引值即可。
完整的工作代码的完整性:
import pulp
prob = pulp.LpProblem("Sudoku_Problem_KA")
prob += 0, "Arbitrary Objective Function"
CAGE_CONSTRAINTS = [
(8., [[0, 0], [0, 1]]),
(9., [[0, 6], [0, 7]]),
(8., [[0, 2], [1, 2]]),
(12., [[0, 3], [0, 4], [1, 3]]),
(15., [[0, 5], [1, 5], [2, 5]]),
(19., [[1, 6], [1, 7], [2, 7]]),
(16., [[0, 8], [1, 8], [2, 8]]),
(14., [[1, 0], [1, 1], [2, 0]]),
(15., [[2, 1], [2, 2]]),
(10., [[2, 3], [3, 3]]),
(12., [[1, 4], [2, 4]]),
(7., [[2, 6], [3, 6]]),
(24., [[3, 0], [3, 1], [4, 1]]),
(17., [[3, 7], [3, 8], [4, 8]]),
(8., [[3, 2], [4, 2]]),
(12., [[4, 3], [5, 3]]),
(19., [[3, 4], [4, 4], [5, 4]]),
(4., [[3, 5], [4, 5]]),
(15., [[4, 6], [5, 6]]),
(12., [[4, 0], [5, 0], [5, 1]]),
(7., [[4, 7], [5, 7], [5, 8]]),
(8., [[5, 2], [6, 2]]),
(10., [[6, 4], [7, 4]]),
(14., [[5, 5], [6, 5]]),
(12., [[6, 6], [6, 7]]),
(18., [[6, 8], [7, 7], [7, 8]]),
(15., [[6, 0], [7, 0], [8, 0]]),
(13., [[6, 1], [7, 1], [7, 2]]),
(12., [[6, 3], [7, 3], [8, 3]]),
(15., [[7, 5], [8, 4], [8, 5]]),
(7., [[7, 6], [8, 6]]),
(10., [[8, 1], [8, 2]]),
(8., [[8, 7], [8, 8]]),
]
# groups that should only have 1 of each number 1-9
row_groups = [[(i, j) for i in range(9)] for j in range(9)]
col_groups = [[(j, i) for i in range(9)] for j in range(9)]
box_groups = [
[(3 * i + k, 3 * j + l) for k in range(3) for l in range(3)]
for i in range(3)
for j in range(3)
]
distinct_groups = row_groups + col_groups + box_groups
# binary choices: rows, columns and values 1-9
choices = pulp.LpVariable.dicts(
"choices", (range(9), range(9), range(1, 10)), cat="Binary"
)
# add constraints that only one choice for each 'distinct_group'
for n in range(1, 10):
for distinct_group in distinct_groups:
prob += pulp.lpSum([choices[i][j][n] for i, j in distinct_group]) <= 1
# add constraints that cells in cages must equal 'cage_total'
for target, cells in CAGE_CONSTRAINTS:
prob += pulp.lpSum([choices[i][j][n] * n for i, j in cells for n in range(1, 10)]) >= target
# only pick one binary value per cell:
for i in range(9):
for j in range(9):
prob += pulp.lpSum([choices[i][j][n] for n in range(1, 10)]) <= 1
prob.solve()
print('Status:',pulp.LpStatus[prob.status])
# Extract results
res = [[sum([choices[i][j][n].varValue*n for n in range(1,10)]) for j in range(9)] for i in range(9)]
# checking a few constraints match
assert res[8][7] + res[8][8] == 8
assert res[0][0] + res[0][1] == 8
print(res)
关于python - Pulp Killer 数独 - 检查变量选择的选择是不同的,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/60248531/
我的填充数独板的代码如下所示: public class SudokuBoard { static int N = 9; static int[][] grid = new int[N
我正在使用“强力”随机方法创建一个数独生成器。我已经能够使用以下代码检查 x/y 轴是否有重复数字: for(l=0; l<9; l++){//Makes all vertical work.
我有一个数独谜题求解器,需要我们使用递归。问题是我检查可用空间的 boolean 值应该通过引用更新当前位置,但事实并非如此。什么会导致这个? public boolean solve() {
我正在尝试为我的项目制作一个数独游戏,但如果我增加数独Grid中的空白空间数量,代码只会抛出异常arrayoutofbounds但是无法弄清楚它来自哪里。 k 是网格中空白空间的数量。 我没有尝试过任
当我尝试编写一个解决数独问题的程序时,我的代码中有一个错误。 我的程序可以运行,但运行效果不佳。它只解决程序中的第一行。 我认为我在那行代码上犯了错误: int ft_rezolva(int **t)
这是我的。该方法应输出该空间中所有可用数字的数组。出于某种原因,这不会过滤掉相同的框/行/列。应该如何正确编码? public int[] getAllowedValues(int row, in
我遇到了一个问题。我是 Java 的新手,正在尝试尝试比以前更复杂的东西。这是我自己的个人文件输入和主要方法与其他方法的一些蚕食源的组合。我对递归仍然很生疏。出于某种原因,更改二维数组“板”中值的分配
嘿,我无法让代码比较给定行或列和 block 的整数,以确保这些参数中没有重复项。我不知道用 3 种不同的方法分离这三个约束是否是一个好主意,或者只是尝试一次完成所有的操作。 public stati
我正在研究 javascript 数独游戏,就输入验证而言,我很困惑。当每个值都输入到数独表中时,我有一个 onkeyup 触发一个函数,我试图用它来确保没有值进入已经存在这样一个值的行/列/框。这是
我正在研究一个小的个人数独游戏并试图扩展它。 到目前为止,我使用递归回溯方法使“求解”部分正常工作,该方法在设法求解递归时返回 true。 现在我正在尝试构建一个独特的解决方案板生成器,并且我在网上找
数独回溯法 int xx = (pos.getX() / 3) * 3; int yy = (pos.getY() / 3) * 3; for (int y =
我是 c++ 的新手,在做作业(数独)时遇到了问题。 说明说:“你必须创建一个新板作为当前板的拷贝(使用复制构造函数并使用 new) 从堆中分配板。” 我试过了(写在board.cc中): #incl
我目前正在使用 java 制作数独游戏,但我似乎无法弄清楚如何正确地循环我的扫描仪。到目前为止,它打印了这个: . 1 . | 3 . . | 8 . . 5 . 9 | 6 . . | 7 . .
关闭。这个问题不满足Stack Overflow guidelines .它目前不接受答案。 想改善这个问题吗?更新问题,使其成为 on-topic对于堆栈溢出。 12 个月前关闭。 Improve
我正在一个由随机生成的数字(从 1 到 4)填充的多维数组中创建一个 4x4 数独游戏。现在我必须搜索重复项并用其他随机数替换它们,直到单行、单列和四个 2x2 子矩阵上都有唯一的数字。我怎样才能做到
我正在制作一个数独板 GUI,它应该看起来像这样 http://www.sudoku.4thewww.com/Grids/grid.jpg 由于某种原因,它只显示最后一个 3*3 板。如果有人能告诉我
嘿,我写了这个程序来解决数独问题,但它只适用于数独矩阵的几个单元格,而其他单元格则返回 0 。你能明白这有什么问题吗?我是 Java 编码新手,无法编写简单的程序真的很痛苦。 public class
这里是 Stack Overflow 的第一个定时器! 首先,我正在使用 JavaFX 创建一个数独求解器。我一切正常,但是,我遇到的唯一问题是创建粗体 3x3 大块,每个大块内有 3x3 单元格。我
我的逻辑求解算法有问题。它很好地解决了具有大量提示的谜题,它只是解决了少于 45 条线索的谜题。 这是求解的算法。 Immutable 是一个 boolean 值,用于确定该值是否可以更改。 cell
我正在尝试使用 Python 线性优化库 Pulp 来解决 killer 数独问题。 https://en.wikipedia.org/wiki/Killer_sudoku 这是我迄今为止的尝试,添加
我是一名优秀的程序员,十分优秀!