數獨解題小程式實現程式碼
自己用Java寫了一個9x9數獨解題的小程序,用的是窮舉法,解一般的題目問題不大
代碼如下:
package Test; public class SensibleGame { /** * @param args */ int[][] mainNumber; boolean[][] flagNumber; public SensibleGame(int[][] mainNumber) { this.mainNumber = mainNumber; flagNumber = new boolean[9][9]; for(int i=0;i<9;i++) { for(int j=0;j<9;j++) { if(mainNumber[i][j] == 0) { flagNumber[i][j] = false; } else { flagNumber[i][j] = true; } } } } public boolean CheckRow(int i, int j)//检查(i,j)位置的行是否满足数独条件 { // 代码省略 } public boolean CheckColumn(int i, int j)//检查(i,j)位置的列是否满足数独条件 { //代码省略 } public boolean CheckRound(int i, int j)//检查(i,j)位置所在的3x3格是否满足数独条件 { //代码省略 } public void run()//计算方法 穷举填数过程 { int i = 0; int j = 0; boolean previousFlag = false; while(true) { if(i<0 || i>8 || j<0 || j>8) { System.out.print("下标越界!"); return; } if(previousFlag == false) { if(flagNumber[i][j] == true) { previousFlag = false; if(i==8 && j==8) { System.out.print("计算结束\n"); break; } else if(i>=0&&i<8&&j==8) { i = i + 1; j = 0; continue; } else { j = j + 1; continue; } } boolean flag = false; int k = 0; while(!flag && k<9) { mainNumber[i][j] = ++k; flag = CheckAll(i, j); } if(flag == true) { previousFlag = false; if(i==8&&j==8) { System.out.println("计算结束\n"); } else if(i>=0&&i<8&&j==8) { i = i + 1; j = 0; continue; } else { j = j + 1; continue; } } else { previousFlag = true; mainNumber[i][j] = 0; if(i==0&&j==0) { System.out.println("计算失败\n"); } else if(i>0&&i<9&&j==0) { i = i -1; j = 8; continue; } else { j = j - 1; continue; } } } else { if(flagNumber[i][j] == true) { previousFlag = true; if(i==0&&j==0) { System.out.println("计算失败\n"); break; } else if(i>0&&i<9&&j==0) { i = i - 1; j = 8; continue; } else { j = j - 1; continue; } } boolean flag = false; while(!flag && mainNumber[i][j]<9 && mainNumber[i][j]>0) { mainNumber[i][j] = mainNumber[i][j] + 1; flag = CheckAll(i, j); } if(flag == true) { previousFlag = false; if(i==8&&j==8) { System.out.println("计算结束\n"); break; } else if(i>=0&&i<8&&j==8) { i = i + 1; j = 0; continue; } else { j = j + 1; continue; } } else { previousFlag = true; mainNumber[i][j] = 0; if(i==0&&j==0) { System.out.println("计算失败\n"); break; } else if(i>0&&i<9&&j==0) { i = i - 1; j = 8; continue; } else { j = j - 1; continue; } } } } } public void Print()//打印 { int k =0; for(int i=0;i<9;i++) { for(int j=0;j<9;j++) { System.out.print(mainNumber[i][j]); if((++k)%9 == 0) { System.out.println(""); } } } } public static void main(String[] args) { // TODO Auto-generated method stub int[][] mainNumber = {{0,9,0,0,1,0,0,2,0}, {7,0,0,0,0,8,3,0,0}, {0,0,0,0,0,0,4,0,0}, {8,3,0,0,0,0,0,1,0}, {0,0,6,0,0,0,0,0,5}, {0,4,0,7,0,0,0,0,0}, {0,0,0,0,0,7,8,9,0}, {0,2,1,0,0,0,0,0,0}, {3,0,0,0,5,0,0,0,6}, }; SensibleGame sensibleGame = new SensibleGame(mainNumber); sensibleGame.run(); sensibleGame.Print(); } }
運行結果如下:
計算結束
493516728
762498351
185372469
837925614
216843975
#54976128314
216843975
#54976128314
216843975
以上是數獨解題小程式實現程式碼的詳細內容。更多資訊請關注PHP中文網其他相關文章!

熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

隨著行動互聯網技術和智慧型手機的普及,微信成為了人們生活中不可或缺的一個應用。而微信小程式則讓人們可以在不需要下載安裝應用程式的情況下,直接使用小程式來解決一些簡單的需求。本文將介紹如何使用Python來開發微信小程式。一、準備工作在使用Python開發微信小程式之前,需要先安裝相關的Python函式庫。這裡推薦使用wxpy和itchat這兩個函式庫。 wxpy是一個微信機器

實作微信小程式中的卡片翻轉特效在微信小程式中,實現卡片翻轉特效是一種常見的動畫效果,可以提升使用者體驗和介面互動的吸引力。以下將具體介紹如何在微信小程式中實現卡片翻轉的特效,並提供相關程式碼範例。首先,需要在小程式的頁面佈局檔案中定義兩個卡片元素,一個用於顯示正面內容,一個用於顯示背面內容,具體範例程式碼如下:<!--index.wxml-->&l

小程式能用react,其使用方法:1、基於「react-reconciler」實作一個渲染器,產生一個DSL;2、建立一個小程式元件,去解析和渲染DSL;3、安裝npm,並執行開發者工具中的建構npm;4、在自己的頁面中引入包,再利用api即可完成開發。

本站10月31日消息,今年5月27日,螞蟻集團宣布啟動“漢字拾光計劃”,最近又迎來新進展:支付寶上線“漢字拾光-生僻字”小程序,用於向社會徵集生僻字,補充生僻字庫,同時提供不同的生僻字輸入體驗,以幫助完善支付寶內的生僻字輸入方法。目前,用戶搜尋「漢字拾光」、「生僻字」等關鍵字就可以進入「生僻字」小程式。在小程式裡,使用者可以提交尚未被系統辨識輸入的生僻字圖片,支付寶工程師確認後,將會對字庫進行補錄入。本站注意到,使用者也可以在小程式體驗最新的拆字輸入法,這項輸入法針對讀音不明確的生僻字設計。用戶拆

uniapp如何實現小程式和H5的快速轉換,需要具體程式碼範例近年來,隨著行動網路的發展和智慧型手機的普及,小程式和H5成為了不可或缺的應用形式。而uniapp作為一個跨平台的開發框架,可以在一套程式碼的基礎上,快速實現小程式和H5的轉換,大大提高了開發效率。本文將介紹uniapp如何實現小程式和H5的快速轉換,並給出具體的程式碼範例。一、uniapp簡介unia

實現思路x01服務端的建立首先,在服務端,使用socket進行訊息的接受,每接受一個socket的請求,就開啟一個新的線程來管理訊息的分發與接受,同時,又存在一個handler來管理所有的線程,從而實現對聊天室的各種功能的處理x02客戶端的建立客戶端的建立就要比服務端簡單多了,客戶端的作用只是對消息的發送以及接受,以及按照特定的規則去輸入特定的字符從而實現不同的功能的使用,因此,在客戶端這裡,只需要去使用兩個線程,一個是專門用於接受消息,一個是專門用於發送消息的至於為什麼不用一個呢,那是因為,只

這篇文章給大家帶來了關於微信小程式的相關問題,其中主要介紹瞭如何在小程式中用公眾號範本訊息,下面一起來看一下,希望對大家有幫助。

1.開啟微信小程序,進入對應的小程式頁面。 2.在小程式頁面中尋找會員相關入口,通常會員入口在底部導覽列或個人中心等位置。 3.點選會員入口,進入會員申請頁。 4、在會員申請頁面,填寫相關信息,如手機號碼、姓名等,完成資料填寫後,提交申請。 5.小程式方會對會員申請審核,審核通過後,用戶即可成為微信小程式會員。 6.作為會員,用戶將享有更多的會員權益,如積分、優惠券、會員專屬活動等
