本文目錄一覽:
java 輸出九宮格
將你其中某些問題的答案放在代碼注釋中了.
這個程序輸出的是固定的九宮格,我想,是根據固有的九宮格中的數字與數組下標的關係來寫的代碼。
希望對你有所幫助,加油!
class S{
public static void main(String[] args) {
int arr[][] = new int[3][3];
//創建一個三階方陣
int a = 2;
//第3行的行下標
//???這裡是什麼意思,2從何而來
//A:java中數組的下標從0開始
int b = 3/2;
//第2列的列下標
//???同上
//A:這裡由於b=1,(int)/(int),java中數組的下標從0開始
for(int i=1;i=9;i++){
//給數組賦值
arr[a++][b++] = i;
if(i%3==0){
//如果i是3的倍數——————???為什麼要判斷是不是3的倍數
a = a-2;
//————————————————???if…else裡面的語句是什麼意思,作用是什麼
b = b-1;//————————————————???同上
}
//使a,b回到起點:a=2,b=1;
else{
//如果i不是3的倍數//————————————————???同上
a = a%3;
b = b%3;
}
}
//????九宮格的每一行、每一列、對角線都等於15,
//???但是這裡連一個15這個數字都沒有出現,但還是成功輸出
//————————————————————???他是怎麼做到的
System.out.println(“輸出九宮格:”);
//遍歷輸出九宮格
for(int i=0;i3;i++){
for(int j=0;j3;j++){
System.out.print(arr[i][j]+” “);
}
System.out.print(“\n”);//從你的程序中將此語句上移到此位置
}
}
}
數獨解題技巧9宮格
口訣法:玩九宮格,掌握一些口訣很重要,比如‘2,4為肩、6,8為足、上9下1、左7右3’總結一下也就是‘294、753、618’ 。
02聯除法:在並排的三個九宮格中的兩排尋找到一些相同的數字,然後再利用九宮格得出另一排中該數字位置,該方法非常適用於中高級數獨。但初期的掌握上會比較困難。
03巡格法:找出在每個九宮格中出現頻率較高的一些數字,再得出該數字在其餘九宮格內位置,該方法一般都是應用於聯除法之後。
04假設法:這種方法就是在某個位置隨機先填上一個數字,然後進行推演,雖然有可能最終產生矛盾而否定結論,但是在高級數獨中還是比較實用。
05排它法:這個方法操作起來稍難一些,就是在各行列或九宮格中觀察,若有個位置其它數字都不能填,就填餘下的數字嘗試推算一下能不能得出結論。
06待定法:這個方法適用性非常高,即暫時確定某個數字在某個區域,再利用其來進行排除。一般來說這個方法都可以搭配其他方法一起使用。
07公式法:這個方法就是將數學的公式帶入到裡邊兒來。以中間的數字為中心,斜着是‘n-1,n,n=1’,從而使得每行數的和是3n。
java編程題,在九宮格內填入1—9九個數字,使得橫豎排的數字相加之和都相等
/*直接複製運行就可以,每一行的九個數字代表一個九宮格的9個數字,從左到右,從上到下*/
import java.util.ArrayList;
import java.util.Arrays;
public class Test1 {
private static ArrayListString arrangeList = new ArrayListString();
public static void main(String[] args) {
String str = “123456789”;//你要排列組合的字符串
char list[] = str.toCharArray();//將字符串轉換為字符數組
genernateData(list, 0, list.length – 1);//參數為字符數組和0和字符數組最大下標
int arr[]=new int[9];
for(String str1 : arrangeList){
for(int k=0;k9;k++){
arr[k]=Integer.parseInt(str1.substring(k,k+1));
}
if(arr[0]+arr[1]+arr[2]==15arr[3]+arr[4]+arr[5]==15arr[6]+arr[7]+arr[8]==15arr[0]+arr[3]+arr[6]==15arr[1]+arr[4]+arr[7]==15arr[2]+arr[5]+arr[8]==15arr[0]+arr[4]+arr[8]==15arr[2]+arr[4]+arr[6]==15){
System.out.println(Arrays.toString(arr));
}
}
}
public static void genernateData(char list[], int k, int m) {
if (k m) {
StringBuffer sb = new StringBuffer();//創建一個StringBuffer對象sb
for (int i = 0; i = m; i++) {
sb.append(list[i]);//循環將字符數組值追加到StringBuffer中
}
arrangeList.add(sb.toString());
} else {
for (int i = k; i = m; i++) {
swapData(list, k, i);//將下表為k和i的值調換位置
genernateData(list, k + 1, m);
swapData(list, k, i);
}
}
}
private static void swapData(char list[], int k, int i) {
char temp = list[k];
list[k] = list[i];
list[i] = temp;
}
}
數獨(九宮格)的規律是什麼?
規律:每一行、每一列、每一個粗線宮(3*3)內的數字均含1-9,不重複。
玩家需要根據9×9盤面上的已知數字,推理出所有剩餘空格的數字,並滿足每一行、每一列、每一個粗線宮(3*3)內的數字均含1-9,不重複。
九宮格遊戲規則,1至9九個數字,橫豎都有3個格,思考怎麼使每行、每列兩個對角線上的三數之和都等於15。這個遊戲不僅僅考驗人的數字推理能力,也同時考驗了人的思維邏輯能力。
「重排九宮」有兩種玩法:
第一種是在在3×3方格盤上,是把1至8八個小木塊隨意擺放,每一空格其周圍的數字可移至空格。玩者要將小木塊按12345678的順序重新排好,以最少的移動次數拼出結果者為勝。
第二種玩法如九宮格算術遊戲玩法,推動木格中8個數字排列,橫豎都有3個格,使每行、每列兩個對角線上的三數之和都等於15。在計算的同時,還必須思考怎麼把數字方塊推動到相對應的位置上,這個遊戲不僅僅考驗人的數字推理能力,也同時考驗了人的思維邏輯能力。
以上內容參考:百度百科-九宮格
原創文章,作者:FEWBI,如若轉載,請註明出處:https://www.506064.com/zh-hant/n/316563.html