【Python】9×9數獨計算器

遊戲規則: 每行每列數字不同,每個九宮格數字不一致,且灰色區域數字不一致!


# 判斷每一行數字是否不同
def check_row(arr):
    for i in arr:
        if(len(i) != len(set(i))):
            return False
    return True
# 判斷每一列數字不相同
def check_col(arr):
    arrDict = []
    for i in range(len(arr)):
        # 讀取每一行的
        for j in range(len(arr[0])):
            arrDict.append(arr[i][j])
        if(len(arrDict) != len(set(arrDict))):
            return False
        else:
            arrDict.clear()
    return True

# 判斷每個九宮格不相同
def check_every(arr):
    #找每個九宮格左上角的點
    dict2 = []
    i = 0
    while (i < len(arr)):
        j = 0
        while (j < len(arr)):
            for m in range(i, i + 3):
                for n in range(j, j + 3):
                    tmp = [m, n]
                    dict2.append(tmp)
            j += 3
        i += 3
    n = 9  # 大列表中幾個數據組成一個小列表
    dict3 = [dict2[i:i + n] for i in range(0, len(dict2), n)]
    checkTmp = []
    for aa in dict3:
        for mm in aa:
            checkTmp.append(arr[mm[0]][mm[1]])
        if (len(checkTmp) != len(set(checkTmp))):
            return False
        checkTmp.clear()
    return True
# 指定區域數字不相同
def check_appoint(arr):
    points = [[1, 1], [1, 5], [5, 1], [5, 5]]
    dict3 = []
    for i in range(len(points)):
        # 遍歷每一個左上角的點
        rowNum = points[i][0]
        colNum = points[i][1]
        dict3.clear()
        for m in range(rowNum, rowNum + 3):
            for n in range(colNum, colNum + 3):
                tmp = [m, n]
                dict3.append(tmp)
        # 讀取列表中每個點對應的值
        listTmp = []
        for point in dict3:
            listTmp.append(arr[point[0]][point[1]])
        if (len(listTmp) != len(set(listTmp))):
            return False
    return True

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

# 每一行都是由1-9構成,所以創建一個標準列表
pipList = [0,1,2,3,4,5,6,7,8,9]
# 數獨中每一行都有數字,減掉已有的,剩下的爲每一行需要填寫的數字
needList = []
for i in range(0,len(arr)):
    needList.append(list(set(pipList).difference(set(arr[i]))))

print(needList)
# 開始往每一行數組中填寫needList[i],編不下去了!!!




if(check_row(arr) & check_col(arr) & check_every(arr) & check_appoint(arr)):
    print(True)
else:
    print(False)

編不下去了,求指教! 

 

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章