输入文件格式:
008309100
900060004
007504800
036000540
001000600
042000970
005907300
600010008
004608200
输出结果:
yuan
********************
0 0 8 3 0 9 1 0 0
9 0 0 0 6 0 0 0 4
0 0 7 5 0 4 8 0 0
0 3 6 0 0 0 5 4 0
0 0 1 0 0 0 6 0 0
0 4 2 0 0 0 9 7 0
0 0 5 9 0 7 3 0 0
6 0 0 0 1 0 0 0 8
0 0 4 6 0 8 2 0 0
********************
result
********************
4 2 8 3 7 9 1 6 5
9 5 3 8 6 1 7 2 4
1 6 7 5 2 4 8 3 9
8 3 6 7 9 2 5 4 1
7 9 1 4 3 5 6 8 2
5 4 2 1 8 6 9 7 3
2 8 5 9 4 7 3 1 6
6 7 9 2 1 3 4 5 8
3 1 4 6 5 8 2 9 7
1 cellArray=[] 2 rowMax=9 3 columnMax=9 4 def pre(): 5 with open(r"C:\Python27\sd.txt") as infile: 6 l=[s for s in infile] 7 for i in range(rowMax): 8 rowArray=[] 9 for j in range(columnMax): 10 c=Cell(i,j) 11 c.value=int(l[i][j]) 12 rowArray.append(c) 13 cellArray.append(rowArray) 14 15 def mynext(c): 16 if c.row+1<rowMax: 17 row=c.row+1 18 column=c.column 19 return cellArray[row][column] 20 elif c.column+1<columnMax: 21 row=0 22 column=c.column+1 23 return cellArray[row][column] 24 else: 25 return None 26 27 class Cell: 28 def __init__(self,row,column): 29 self.row=row 30 self.column=column 31 self.value=0 32 def __str__(self): 33 return str(self.row)+":"+str(self.column)+":"+str(self.value) 34 35 def setCellValue(cell): 36 if cell==None: 37 return True 38 if cell.value==0: 39 canList=[1,2,3,4,5,6,7,8,9] 40 blockCheck(canList,cell) 41 rowCheck(canList,cell) 42 columnCheck(canList,cell) 43 if len(canList) ==0: 44 return False 45 for canNum in canList: 46 cell.value=canNum 47 res=setCellValue(mynext(cell)) 48 if res: 49 return True 50 cell.value=0 51 return False 52 else: 53 return setCellValue(mynext(cell)) 54 def blockCheck(canList,cell): 55 blockrow=cell.row/3 56 blockcolumn=cell.column/3 57 for i in range(blockrow*3,(blockrow+1)*3): 58 for j in range(blockcolumn*3,(blockcolumn+1)*3): 59 cvalue=cellArray[i][j].value 60 if cellArray[i][j].value==0: 61 continue 62 if cvalue in canList: 63 canList.remove(cvalue) 64 65 def rowCheck(canList,cell): 66 for i in range(columnMax): 67 cvalue=cellArray[cell.row][i].value 68 if cvalue==0: 69 continue 70 if cvalue in canList: 71 canList.remove(cvalue) 72 73 def columnCheck(canList,cell): 74 for i in range(rowMax): 75 cvalue=cellArray[i][cell.column].value 76 if cvalue==0: 77 continue 78 if cvalue in canList: 79 canList.remove(cvalue) 80 81 print ‘yuan‘ 82 print ‘*‘*20 83 pre() 84 for i in range(rowMax): 85 for j in range(columnMax): 86 print str(cellArray[i][j].value), 87 print "\n" 88 89 print ‘*‘*20 90 print ‘result‘ 91 print ‘*‘*20 92 setCellValue(cellArray[0][0]) 93 for i in range(rowMax): 94 for j in range(columnMax): 95 print str(cellArray[i][j].value), 96 print "\n"
python 实现计算数独
时间: 2024-10-25 13:49:11