日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術文章
文章詳情頁

Java二維數組實現數字拼圖效果

瀏覽:28日期:2022-08-08 17:41:32

二維數組實現數字拼圖,供大家參考,具體內容如下

二維數組可以自己隨意定義大小,通過方法判斷來實現對所有的數字進行隨機打亂,并可以通過移動來正確還原,并可以判斷0(表示空格)是否可以移動,是否在范圍內。

public static void main(String[] args) { Scanner scanner = new Scanner(System.in); int[][] arrays = { { 1, 2, 3 }, { 4, 5, 6 }, { 7, 8, 0 } }; int sum = 1; String direction; bianLi(arrays); daLuanErWeiShuZu(arrays); System.out.println('========================================'); while (true) { bianLi(arrays); if (isOk(arrays)) { break; } sum++; try { Thread.sleep(500); } catch (InterruptedException e) { // TODO Auto-generated catch block e.printStackTrace(); } System.out.println('請輸入移動方向(W 上、S 下、A 左、D 右)'); direction = scanner.next(); switch (direction) { case 'W': case 'w': tiHuanShuZuWeiZhi(returnX(arrays), returnY(arrays), '上', arrays); break; case 'S': case 's': tiHuanShuZuWeiZhi(returnX(arrays), returnY(arrays), '下', arrays); break; case 'A': case 'a': tiHuanShuZuWeiZhi(returnX(arrays), returnY(arrays), '左', arrays); break; case 'D': case 'd': tiHuanShuZuWeiZhi(returnX(arrays), returnY(arrays), '右', arrays); break; default: System.out.println('非法輸入,重新輸入'); break; } } System.out.println('一共走了' + sum + '步'); System.out.println('挑戰成功');}

判斷當前坐標是否可以移動

/** * 判斷當前坐標是否可以移動 * * @param arrays * @return 可以移動返回true */ public static boolean isYiDong(int[][] arrays) { int returnX = returnX(arrays); int returnY = returnY(arrays); System.out.println(returnX + ':' + returnY); if (returnX >= 0 && returnX + 1 < arrays.length && returnY >= 0 && returnY + 1 < arrays.length) { return true; } return false; }

獲取當前0所在行的具體地址

// 獲取0所在行的位置 public static int returnX(int[][] arrays) { for (int i = 0; i < arrays.length; i++) { for (int j = 0; j < arrays[i].length; j++) { if (0 == arrays[i][j]) { return i; } } } return -1; }

獲取當前0所在列的具體地址

// 獲取0所在列的位置 public static int returnY(int[][] arrays) { for (int i = 0; i < arrays.length; i++) { for (int j = 0; j < arrays[i].length; j++) { if (0 == arrays[i][j]) { return j; } } } return -1; }

二維數組隨機打亂,需要判斷左上角、右上角、左下角、右下角、中間、上中、下種、左中、右中,那些方向可以移動,生成隨機數來確定移動方向

// 二維數組隨機打亂 public static void daLuanErWeiShuZu(int[][] arrays) { for (int i = 0; i < arrays.length; i++) { for (int j = 0; j < arrays[i].length; j++) { // 左上 if (i == 0 && j == 0) { // 根據生成的隨機數確定向右邊邊移動還是向下移動 if (ouShuOrJiShu()) { tiHuanShuZuWeiZhi(i, j, '下', arrays); } else { tiHuanShuZuWeiZhi(i, j, '右', arrays); } } // 右上 if (i == 0 && j == arrays[0].length - 1) { // 根據生成的隨機數確定向左邊邊移動還是向下移動 if (ouShuOrJiShu()) { tiHuanShuZuWeiZhi(i, j, '下', arrays); } else { tiHuanShuZuWeiZhi(i, j, '左', arrays); } } // 左下 if (i == arrays.length - 1 && j == 0) { // 根據生成的隨機數確定向左邊邊移動還是向下移動 if (ouShuOrJiShu()) { tiHuanShuZuWeiZhi(i, j, '上', arrays); } else { tiHuanShuZuWeiZhi(i, j, '右', arrays); } } // 右下 if (i == arrays.length - 1 && j == arrays[i].length - 1) { // 根據生成的隨機數確定向左邊邊移動還是向下移動 if (ouShuOrJiShu()) { tiHuanShuZuWeiZhi(i, j, '上', arrays); } else { tiHuanShuZuWeiZhi(i, j, '左', arrays); } } // 上中 if (i == 0 && j > 0 && j < arrays[i].length - 1) { switch (oneToThree(3)) { case 0: tiHuanShuZuWeiZhi(i, j, '右', arrays); break; case 1: tiHuanShuZuWeiZhi(i, j, '下', arrays); break; case 2: tiHuanShuZuWeiZhi(i, j, '左', arrays); break; default: break; } } // 左中 if (j == 0 && i > 0 && i < arrays.length - 1) { switch (oneToThree(3)) { case 0: tiHuanShuZuWeiZhi(i, j, '上', arrays); break; case 1: tiHuanShuZuWeiZhi(i, j, '右', arrays); break; case 2: tiHuanShuZuWeiZhi(i, j, '下', arrays); break; default: break; } } // 下中 if (i == arrays.length - 1 && j > 0 && j < arrays[i].length - 1) { switch (oneToThree(3)) { case 0: tiHuanShuZuWeiZhi(i, j, '上', arrays); break; case 1: tiHuanShuZuWeiZhi(i, j, '右', arrays); break; case 2: tiHuanShuZuWeiZhi(i, j, '左', arrays); break; default: break; } } // 右中 if (j == arrays[i].length - 1 && i > 0 && i < arrays[i].length - 1) { switch (oneToThree(3)) { case 0: tiHuanShuZuWeiZhi(i, j, '上', arrays); break; case 1: tiHuanShuZuWeiZhi(i, j, '左', arrays); break; case 2: tiHuanShuZuWeiZhi(i, j, '下', arrays); break; default: break; } } if (i > 0 && j > 0 && i < arrays.length - 2 && j < arrays[i].length - 2) { switch (oneToThree(4)) { case 0: tiHuanShuZuWeiZhi(i, j, '上', arrays); break; case 1: tiHuanShuZuWeiZhi(i, j, '右', arrays); break; case 2: tiHuanShuZuWeiZhi(i, j, '下', arrays); break; case 3: tiHuanShuZuWeiZhi(i, j, '左', arrays); break; default: break; } } } } }

該方法實現對0的位置和需要替換位置數據的替換,并對0范圍進行驗證,怕0出現數組下標越位。

/** * 根據輸入的數據,對二維數組進行數據替換 * * @param i 高位坐標 * @param j 地位坐標 * @param direction 移動方向 * @param arrays 需要交換數據的數組 */ public static void tiHuanShuZuWeiZhi(int i, int j, String direction, int[][] arrays) { int tem = -1; switch (direction) { case '上': if (i > 0) { tem = arrays[i][j]; arrays[i][j] = arrays[i - 1][j]; arrays[i - 1][j] = tem; } break; case '下': if (i < arrays.length - 1) { tem = arrays[i][j]; arrays[i][j] = arrays[i + 1][j]; arrays[i + 1][j] = tem; } break; case '左': if (j > 0) { tem = arrays[i][j]; arrays[i][j] = arrays[i][j - 1]; arrays[i][j - 1] = tem; } break; case '右': if (j < arrays.length - 1) { tem = arrays[i][j]; arrays[i][j] = arrays[i][j + 1]; arrays[i][j + 1] = tem; } break; default: break; } }

完整代碼如下

import java.util.Random;import java.util.Scanner;public class Demo { public static void main(String[] args) { Scanner scanner = new Scanner(System.in); int[][] arrays = { { 1, 2, 3 }, { 4, 5, 6 }, { 7, 8, 0 } }; int sum = 1; String direction; bianLi(arrays); daLuanErWeiShuZu(arrays); System.out.println('========================================'); while (true) { bianLi(arrays); if (isOk(arrays)) { break; } sum++; try { Thread.sleep(500); } catch (InterruptedException e) { // TODO Auto-generated catch block e.printStackTrace(); } System.out.println('請輸入移動方向(W 上、S 下、A 左、D 右)'); direction = scanner.next(); switch (direction) { case 'W': case 'w': tiHuanShuZuWeiZhi(returnX(arrays), returnY(arrays), '上', arrays); break; case 'S': case 's': tiHuanShuZuWeiZhi(returnX(arrays), returnY(arrays), '下', arrays); break; case 'A': case 'a': tiHuanShuZuWeiZhi(returnX(arrays), returnY(arrays), '左', arrays); break; case 'D': case 'd': tiHuanShuZuWeiZhi(returnX(arrays), returnY(arrays), '右', arrays); break; default: System.out.println('非法輸入,重新輸入'); break; } } System.out.println('一共走了' + sum + '步'); System.out.println('挑戰成功'); }// /**// * 判斷當前坐標是否可以移動// * // * @param arrays// * @return 可以移動返回true// */// public static boolean isYiDong(int[][] arrays) {// int returnX = returnX(arrays);// int returnY = returnY(arrays);// System.out.println(returnX + ':' + returnY);// if (returnX >= 0 && returnX + 1 < arrays.length && returnY >= 0 && returnY + 1 < arrays.length) {// return true;// }// return false;// } /** * * @param arrays 需要驗證的數據 * @return 成功返回true */ public static boolean isOk(int[][] arrays) { int sum = 1; for (int i = 0; i < arrays.length; i++) { for (int j = 0; j < arrays.length; j++) { if (sum == 9) { sum = 0; } if (arrays[i][j] != sum) { return false; } sum++; } } return true; } // 獲取0所在行的位置 public static int returnX(int[][] arrays) { for (int i = 0; i < arrays.length; i++) { for (int j = 0; j < arrays[i].length; j++) { if (0 == arrays[i][j]) { return i; } } } return -1; } // 獲取0所在列的位置 public static int returnY(int[][] arrays) { for (int i = 0; i < arrays.length; i++) { for (int j = 0; j < arrays[i].length; j++) { if (0 == arrays[i][j]) { return j; } } } return -1; } // 遍歷二維數組 public static void bianLi(int[][] arrays) { for (int[] is : arrays) { for (int is2 : is) { System.out.print(is2 + 't'); } System.out.println(); } } // 二維數組隨機打亂 public static void daLuanErWeiShuZu(int[][] arrays) { for (int i = 0; i < arrays.length; i++) { for (int j = 0; j < arrays[i].length; j++) { // 左上 if (i == 0 && j == 0) { // 根據生成的隨機數確定向右邊邊移動還是向下移動 if (ouShuOrJiShu()) { tiHuanShuZuWeiZhi(i, j, '下', arrays); } else { tiHuanShuZuWeiZhi(i, j, '右', arrays); } } // 右上 if (i == 0 && j == arrays[0].length - 1) { // 根據生成的隨機數確定向左邊邊移動還是向下移動 if (ouShuOrJiShu()) { tiHuanShuZuWeiZhi(i, j, '下', arrays); } else { tiHuanShuZuWeiZhi(i, j, '左', arrays); } } // 左下 if (i == arrays.length - 1 && j == 0) { // 根據生成的隨機數確定向左邊邊移動還是向下移動 if (ouShuOrJiShu()) { tiHuanShuZuWeiZhi(i, j, '上', arrays); } else { tiHuanShuZuWeiZhi(i, j, '右', arrays); } } // 右下 if (i == arrays.length - 1 && j == arrays[i].length - 1) { // 根據生成的隨機數確定向左邊邊移動還是向下移動 if (ouShuOrJiShu()) { tiHuanShuZuWeiZhi(i, j, '上', arrays); } else { tiHuanShuZuWeiZhi(i, j, '左', arrays); } } // 上中 if (i == 0 && j > 0 && j < arrays[i].length - 1) { switch (oneToThree(3)) { case 0: tiHuanShuZuWeiZhi(i, j, '右', arrays); break; case 1: tiHuanShuZuWeiZhi(i, j, '下', arrays); break; case 2: tiHuanShuZuWeiZhi(i, j, '左', arrays); break; default: break; } } // 左中 if (j == 0 && i > 0 && i < arrays.length - 1) { switch (oneToThree(3)) { case 0: tiHuanShuZuWeiZhi(i, j, '上', arrays); break; case 1: tiHuanShuZuWeiZhi(i, j, '右', arrays); break; case 2: tiHuanShuZuWeiZhi(i, j, '下', arrays); break; default: break; } } // 下中 if (i == arrays.length - 1 && j > 0 && j < arrays[i].length - 1) { switch (oneToThree(3)) { case 0: tiHuanShuZuWeiZhi(i, j, '上', arrays); break; case 1: tiHuanShuZuWeiZhi(i, j, '右', arrays); break; case 2: tiHuanShuZuWeiZhi(i, j, '左', arrays); break; default: break; } } // 右中 if (j == arrays[i].length - 1 && i > 0 && i < arrays[i].length - 1) { switch (oneToThree(3)) { case 0: tiHuanShuZuWeiZhi(i, j, '上', arrays); break; case 1: tiHuanShuZuWeiZhi(i, j, '左', arrays); break; case 2: tiHuanShuZuWeiZhi(i, j, '下', arrays); break; default: break; } } if (i > 0 && j > 0 && i < arrays.length - 2 && j < arrays[i].length - 2) { switch (oneToThree(4)) { case 0: tiHuanShuZuWeiZhi(i, j, '上', arrays); break; case 1: tiHuanShuZuWeiZhi(i, j, '右', arrays); break; case 2: tiHuanShuZuWeiZhi(i, j, '下', arrays); break; case 3: tiHuanShuZuWeiZhi(i, j, '左', arrays); break; default: break; } } } } } /** * 判斷是否是偶數 * * @return 偶數返回true */ public static boolean ouShuOrJiShu() { return new Random().nextInt(1000) % 2 == 0 ? true : false; } /** * * @param n 需要模的值 * @return 返回0-(n-1)的值 */ public static int oneToThree(int n) { return new Random().nextInt(1000) % n; } /** * 根據輸入的數據,對二維數組進行數據替換 * * @param i 高位坐標 * @param j 地位坐標 * @param direction 移動方向 * @param arrays 需要交換數據的數組 */ public static void tiHuanShuZuWeiZhi(int i, int j, String direction, int[][] arrays) { int tem = -1; switch (direction) { case '上': if (i > 0) { tem = arrays[i][j]; arrays[i][j] = arrays[i - 1][j]; arrays[i - 1][j] = tem; } break; case '下': if (i < arrays.length - 1) { tem = arrays[i][j]; arrays[i][j] = arrays[i + 1][j]; arrays[i + 1][j] = tem; } break; case '左': if (j > 0) { tem = arrays[i][j]; arrays[i][j] = arrays[i][j - 1]; arrays[i][j - 1] = tem; } break; case '右': if (j < arrays.length - 1) { tem = arrays[i][j]; arrays[i][j] = arrays[i][j + 1]; arrays[i][j + 1] = tem; } break; default: break; } }}

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持好吧啦網。

標簽: Java
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
婷婷亚洲精品| 人人香蕉久久| 亚洲少妇诱惑| 亚洲欧美日本视频在线观看| 六月婷婷一区| 亚洲欧洲专区| 日本欧美在线| 国产麻豆精品| 精品中文字幕一区二区三区| 国产成人精品福利| 婷婷综合六月| 99在线|亚洲一区二区| 国产精品视区| 日韩一区中文| 欧美日韩国产一区二区在线观看| 国产精品日韩精品中文字幕| 麻豆成人综合网| 91tv亚洲精品香蕉国产一区| 婷婷成人基地| 日韩精品亚洲专区| 麻豆精品蜜桃视频网站| 色偷偷色偷偷色偷偷在线视频| 久久精品国产99久久| 午夜亚洲福利在线老司机| 亚洲精品福利| 精品亚洲成人| 美女网站一区| 日本麻豆一区二区三区视频| 精品日韩在线| 国产专区一区| 亚洲久久视频| 精品国产黄a∨片高清在线| 久久国产成人午夜av影院宅| 一区二区三区网站| 麻豆精品久久久| 亚洲一级特黄| 一区二区精彩视频| 国产一区二区三区四区二区| 欧美午夜不卡| 国产精品一页| japanese国产精品| 91麻豆精品激情在线观看最新 | 麻豆高清免费国产一区| 欧美精品日日操| 亚洲精品在线二区| 成人三级高清视频在线看| 日韩视频久久| 国产精品亚洲综合久久| 久久夜夜操妹子| 涩涩涩久久久成人精品| 久久久久久自在自线| 亚洲香蕉久久| 久久久久久久久久久妇女| 日韩精品五月天| 欧美日韩精品免费观看视欧美高清免费大片 | 欧美aaaaaa午夜精品| 国产一在线精品一区在线观看| 日韩成人精品一区二区三区 | 亚洲激情中文| 国产欧美成人| 国产一区亚洲| 欧美国产极品| 伊人精品久久| 欧美日韩一区二区三区视频播放| 日韩av一二三| 日韩午夜av| 国产aⅴ精品一区二区三区久久| 黄色成人精品网站| 久久精品免费看| 日韩有吗在线观看| 激情自拍一区| 老牛国内精品亚洲成av人片| 麻豆精品91| 欧美成人基地| 久久香蕉精品香蕉| 亚洲日本欧美| 亚洲大全视频| 国产日韩电影| 欧美极品中文字幕| 日韩国产欧美一区二区三区| 免费观看不卡av| 亚洲天堂资源| 91精品麻豆| 一本综合精品| 国产精品丝袜xxxxxxx| 成人亚洲欧美| 欧美国产精品| 日本三级亚洲精品| 鲁大师成人一区二区三区| 日本精品在线中文字幕| 久久99国产精品视频| 91精品国产自产观看在线| 免费日韩av片| aⅴ色国产欧美| 久久中文字幕av| yellow在线观看网址| 国产精品1区在线| 日韩精品久久久久久| 爽好久久久欧美精品| 亚洲国产一区二区在线观看 | 蜜臀av性久久久久蜜臀aⅴ四虎 | 亚洲天堂久久| 国产66精品| 麻豆91精品91久久久的内涵| 欧美精品观看| 啪啪亚洲精品| 综合亚洲色图| 久久国产精品亚洲77777| 精品91久久久久| 一区福利视频| 91久久午夜| 欧美一区=区| 蜜臀久久99精品久久久久久9| 亚洲作爱视频| 麻豆精品91| 亚洲人亚洲人色久| 日本不卡高清| 欧美日韩亚洲一区在线观看| 青草av.久久免费一区| 日韩欧美久久| 国产免费av国片精品草莓男男| 日本午夜精品一区二区三区电影| 欧美综合另类| 久久91导航| 成人福利一区 | 天海翼精品一区二区三区| 免费日韩av| 在线观看一区| 日本麻豆一区二区三区视频| 国产免费av国片精品草莓男男 | 国产精品一区二区三区美女| 国产精品亚洲二区| 精品国产亚洲一区二区在线观看| 麻豆精品久久| 蜜桃视频在线网站| 久久久精品日韩| 国产综合激情| 亚洲天堂av资源在线观看| 日韩欧美精品一区二区综合视频| 国产美女视频一区二区| 精品久久一区| 亚洲大片在线| 一级成人国产| 国产伦理一区| 欧美一级鲁丝片| 亚洲欧美日韩国产一区| 日韩一区二区三免费高清在线观看| 日本视频在线一区| 久久中文字幕一区二区三区| 成人羞羞视频播放网站| 久久精品国产68国产精品亚洲| 欧美精品黄色| 91大神在线观看线路一区| 国产精品xxx| 视频福利一区| 亚洲美女久久| 国模大尺度视频一区二区| 久久麻豆精品| 日韩av一区二区三区四区| 六月婷婷综合| 国产亚洲毛片在线| 欧美一区自拍| 日韩啪啪电影网| 久热精品在线| 精品一区二区三区中文字幕| 久久精品动漫| 日韩精彩视频在线观看| 亚洲欧洲美洲av| 在线精品观看| 国产一区调教| 免费日本视频一区| 国产麻豆精品久久| 久久久久99| 欧美自拍一区| 日韩中文视频| 日韩av午夜在线观看| 伊人久久国产| 亚洲精品日韩久久| 色婷婷亚洲mv天堂mv在影片| 玖玖玖国产精品| 久久中文精品| 午夜在线视频观看日韩17c| 美女毛片一区二区三区四区最新中文字幕亚洲 | 日韩三区在线| 青青草伊人久久| 欧美特黄一级大片| 欧美欧美黄在线二区| 99久久夜色精品国产亚洲1000部 | 日韩av网站在线观看| 午夜av成人| 国产精品亚洲综合色区韩国| 999国产精品999久久久久久| 日韩高清国产一区在线| 亚洲国产专区| 麻豆久久久久久| 免费日本视频一区| 天堂а√在线最新版中文在线| 亚洲精品乱码| 成人久久一区| 久草精品视频|