国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > Python > 正文

python實現(xiàn)自動解數(shù)獨小程序

2020-02-16 00:46:25
字體:
供稿:網(wǎng)友

跟朋友最近聊起來數(shù)獨游戲,突發(fā)奇想使用python編寫一個自動計算數(shù)獨解的小程序。

數(shù)獨的規(guī)則不再過多闡述,在此描述一下程序的主要思路:

(當(dāng)前程序只針對于簡單的數(shù)獨,更復(fù)雜的還待深入挖掘)

1.計算當(dāng)前每個空格可能的取值集合,并將空格順序值對應(yīng)取值集合置于字典中;

2.對取值集合位數(shù)為1,即空格處為單一取值的進(jìn)行賦值,(填入動作),重復(fù)1刷新字典直到字典為空位置;

當(dāng)前實現(xiàn)如下:

1.將數(shù)獨輸入列表中,并定義函數(shù)count_candinate_number(j)根據(jù)數(shù)獨規(guī)則計算每一個為0的位置的當(dāng)前可能取值:

#編輯數(shù)獨題目,將題目輸入列表中question = [6,0,7,0,0,0,9,0,3,  0,0,8,0,0,7,0,0,0,  3,0,0,0,8,2,0,7,5,  0,1,2,3,0,5,0,0,0,  0,0,6,0,0,0,5,0,0,  0,0,0,4,0,6,7,1,0,  2,6,0,7,4,0,0,0,8,  0,0,0,8,0,0,6,0,0,  7,0,5,0,0,0,1,0,9] # print(question[0]) #返回當(dāng)前數(shù)獨為0的空格中所有可能取值def count_candidate_number(j): exist_all_number = [] #當(dāng)前橫豎大方格內(nèi)所有出現(xiàn)的數(shù)字集 candidate_number = [] #該方格內(nèi)所有的數(shù)字候選集 SD_Row = int(j) // 9 #行 SD_Column = int(j) % 9 #列  #用迭代器寫 exist_all_number_part1 = [question[i+SD_Row*9] for i in range(9)] #橫-出現(xiàn)的所有數(shù)字集 exist_all_number_part2 = [question[i*9+SD_Column] for i in range(9)] #豎-出現(xiàn)的所有數(shù)字集 exist_all_number_part3 = [question[((j//9)//3)*27+((j % 9)//3)*3+i] for i in range(3)]+[question[((j//9)//3)*27+((j % 9)//3)*3+9+i] for i in range(3)]+[question[((j//9)//3)*27+((j % 9)//3)*3+18+i] for i in range(3)] #大方塊-出現(xiàn)的所有數(shù)字集 exist_all_number = list(set(exist_all_number_part1+exist_all_number_part2+exist_all_number_part3))  #對出現(xiàn)所有的數(shù)字集組合及去重 # print(exist_all_number)  #用循環(huán)寫 # for i in range(9): # if question[i+SD_Row*9] not in exist_all_number: #  exist_all_number.append(question[i+SD_Row*9]) # if question[i*9 + SD_Cloumn] not in exist_all_number: #  exist_all_number.append(question[i*9 + SD_Cloumn]) # # print(exist_all_number)  #迭代器寫 candidate_number = [i for i in range(1, 10) if i not in exist_all_number] #對可能取值進(jìn)行迭代輸出  #用循環(huán)寫 # for i in range(1,10): # if i not in exist_all_number: #  candidate_number.append(i) # print(candidate_number)  return candidate_number

2.定義函數(shù)求解對應(yīng)每個為0的位置的可能求解,并將位置信息與可能求解以鍵-鍵值的形式存儲于字典中:

#對數(shù)組中每個為0的空格列出所有可能的取值數(shù)集,并放置于字典中def all_possible_candidate_number(): all_possible_candidate_number = {i:count_candidate_number(i) for i in range(81) if question[i] == 0} return all_possible_candidate_number # print(all_possible_candidate_number)

3.對每一個位置的可能求解進(jìn)行判斷,若可能解只有一個,則填入該解,循環(huán)直至數(shù)獨求解完成

發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 海晏县| 当阳市| 公安县| 镇坪县| 阳江市| 新野县| 来安县| 衡水市| 邓州市| 乾安县| 青川县| 民权县| 广汉市| 正蓝旗| 涪陵区| 双辽市| 宁阳县| 重庆市| 紫金县| 桃源县| 兰西县| 西城区| 邮箱| 乃东县| 肇源县| 大城县| 民勤县| 洪湖市| 靖宇县| 泸定县| 句容市| 西和县| 丰城市| 龙陵县| 乌拉特后旗| 天镇县| 花垣县| 如东县| 鹤壁市| 克山县| 德庆县|