數(shù)獨(dú)(Sudoku)問(wèn)題的Python實(shí)現(xiàn)

數(shù)獨(dú)是一種小游戲。規(guī)則是在一個(gè)9*9或者其他型號(hào)的板子上填數(shù)字,必須滿足三個(gè)要求:1.每一個(gè)橫排的9個(gè)空格必須是1到9之間的互相不重復(fù)的一個(gè)數(shù)字。2.每一個(gè)豎排的9個(gè)空格必須是1到9之間的互相不重復(fù)的一個(gè)數(shù)字。3.每一個(gè)3*3的小單元(1~3,3~6,6~9)必須是1到9之間的互相不重復(fù)的一個(gè)數(shù)字。

下面是幾個(gè)重要的定義:

定義1(Sudoku Solution): The solution of a Sudoku puzzle requires that every row, column, and box contain all the numbers in the set [1,2,...,9] and that every cell is occupied by one and only one number.

定義2(Preemptive Sets): A preemptive?set is composed of numbers from the set [1,2,...,9] and is a set of size m, 2<= m <= 9, whose number are potential occupants of m cells exclusively, where exclusively means that no other numbers in the set [1,2,...,9] other than the members of those m cells.

解數(shù)獨(dú)的算法:

第一步:找到所有forced numbers 在數(shù)獨(dú)中的。(方法: 利用數(shù)獨(dú)的定義,先全部markup,然后判斷每一行,列和九宮格中是否只有唯一的數(shù),如果有就標(biāo)記為確定的forced)

第二步:Mark up 數(shù)獨(dú)。(把所有的可能值分別填入不同的表格中)

第三步:迭代搜索preemptive sets(先發(fā)制人集合)在所有的行,列和九宮格中,劃掉被排除的數(shù)。

第四步:(a)找到了結(jié)果

? ? ? ? ? ? ? ?(b)必須隨機(jī)選一個(gè)數(shù)繼續(xù)往下找

第五步:如果4(a)成立,那么結(jié)束:如果4(b)成立,那么重新執(zhí)行第三步。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書(shū)系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容