电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

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

Java實現簡單井字棋小游戲代碼實例

瀏覽:2日期:2022-09-04 14:43:16

Java實現簡單井字棋小游戲代碼實例

Java第一次實驗,老師讓做一個井字棋,電腦隨機下棋。

然后就想能不能聰明一點,可以判斷出走哪一步棋;然后只能做到不會輸,還是不夠聰明,只能呆板地堵住用戶,smartRobot的第三個判斷邏輯找不到最佳位置,贏得概率比較小;而且我沒事干時,想玩玩這個小游戲找找成就感,但每次都會贏了機器人,所以刪刪改改了四五次,最后才成。

可以選擇誰先開始,但startGame里的代碼更加冗余了??粗秃軄y,但沒想到好的辦法。

smartRobot里的代碼全部重寫了,比原來更聰明一點了:下在四個角的位置時,能優先選擇最佳位置;然后沒有最佳位置時,再隨便找一空的(隨便找空四角位置使用for代替了,比原來更簡短)。

然后smartRobot的第一個和第三個判斷邏輯,也更聰明一點了。原來判斷機器人和判斷用戶的邏輯,是放在一個for循環里的,但無法找到最佳位置,現在分開了。

機器人先開始時,才能發揮出來新添加的機器人的“小聰明”;但機器人原來的能力發揮不回來,只有用戶先開始時才能發揮出原來的能力。所以各有利弊,無論誰先開始都能適應。如果機器人先開始,并且用戶第一步棋不是下在四角的位置,那么用戶就必輸了。其他的情況一般都是平局了。

想到一個因為可以選擇誰先開始而導致 startGame 代碼冗余的問題的解決方法,就是使用局部內部類。內部類能訪問到方法的局部對象。

主邏輯 startGame:

1. 用一個3X3的二維數組,存儲棋盤;

2. 用戶輸入1~9下棋;

3. 判斷是否合法,不合法則重新輸入;

4. 將1~9轉換成二維的坐標 x = (pos-1)/3, y = (pos-1)%3,再令二維數組相應位置為 ’O’;

5. 判斷用戶是否勝利,是則退出;再判斷是否平局,是則退出;

6. 機器人下棋(根據輸入等級,調用不同函數);

7. 打印棋盤顯示出用戶和機器人下的棋子;

8. 判斷機器人是否勝利,是則退出;再判斷是否平局,是則退出;都不是返回第1步。

isSuccessful 判斷成功的邏輯:

判斷所有行、列、對角線是否有連成一條線的,用字符相加的和判斷即可

willBeSuccessful判斷是否將要成功:

這里判斷的是是否有行、列有兩個相同棋子和一個空白,用字符相加的和判斷。

calculate 計算行列對角線:

使用枚舉類,來判斷是計算行,還是計算列,還是計算左右對角線;計算行列時,傳入一個1~3的數字表示是哪一行那一列。

smartRobot 的第一個判斷邏輯:

如果棋子下在箭頭指向的那個位置,那么一步棋就可勝利。

機器人先判斷自己是否有這樣一個位置,有則下在哪個地方,勝利;

方法是嘗試填入所有空白地方,每填一次,判斷一次 isSuccessful;

如果沒有,再判斷對方是否有這樣一個位置,有則堵住這個地方。

Java實現簡單井字棋小游戲代碼實例

smartRobot 的第三個判斷邏輯:

如果棋子下在箭頭指向的位置,那么再下一步必會勝利,因為下在了那個地方,第三列、第三行都是兩個棋子了,無論對方堵哪里,都會失敗。

也是機器人先判斷自己是否有這樣一個位置,有則下;

調用 willBeSuccessful 判斷是否有這樣的位置。

沒有則再判斷對方是否有這樣的位置,有則堵住。

Java實現簡單井字棋小游戲代碼實例

smartRobot 的第零個和第二個判斷邏輯:

處理四個角和中心的位置,如果用戶下在了中心,那么機器人必須至少有兩個棋子下在四角位置才能保證不輸。

更改了無數次的代碼:

import java.util.Arrays;import java.util.Scanner; public class Experiment_1 { public static void main(String[] args) { ThreeChess game = new ThreeChess(); game.startGame(); }} class ThreeChess{ private char[][] chessBoard = new char[3][3]; private int size = 0; //已經下的棋數 private final int CAPACITY = 9; //總共可下的棋數 ThreeChess(){ for(char[] line : chessBoard){ //初始化棋盤 Arrays.fill(line, ’ ’); } } //【游戲開始】 public void startGame(){ System.out.println('┌───┬───┬───┐'); System.out.println('│ 1 │ 2 │ 3 │'); System.out.println('├───┼───┼───┤'); System.out.println('│ 4 │ 5 │ 6 │'); System.out.println('├───┼───┼───┤'); System.out.println('│ 7 │ 8 │ 9 │'); System.out.println('└───┴───┴───┘'); System.out.println('輸入 1 ~ 9 表示要下棋的位置'); System.out.println('O是你的棋子,*是電腦的棋子'); Scanner in = new Scanner(System.in); System.out.print('選擇誰先開始:nt1.用戶nt2.機器人nInput: '); int whoFirst = in.nextInt(); System.out.print('選擇機器人智商:nt1. 999+nt2. 250nInput: '); int level = in.nextInt(); class Play{ //代碼重用 //方法返回-1表示退出 int robotPlay(){if(level == 1) smartRobot();else sillyRobot(); printChessBroad();if(isSuccessful() == -1) { System.out.println('機器人勝 (/ □ )'); return -1;}else if (size == CAPACITY){ System.out.println('==游戲平局=='); return -1;}return 0; } int userPlay(){int pos;while(true){ System.out.print('下棋位置: '); pos = in.nextInt(); if(pos < 1 || pos > 9 || chessBoard[(pos - 1) / 3][(pos - 1) % 3] != ’ ’){ System.out.println('輸入錯誤,重新輸入!'); continue; } else { chessBoard[(pos - 1)/3][(pos - 1) % 3] = ’O’; size++; break; }} if(isSuccessful() == 1){ printChessBroad(); System.out.println('恭喜,你勝了 ?(*°?°*)?'); return -1;} else if(size == CAPACITY){ printChessBroad(); System.out.println('==游戲平局=='); return -1;}return 0; } } Play play = new Play(); if(whoFirst == 2){ while(true){//1.機器人下棋if(play.robotPlay() == -1) return; //2.用戶下棋if(play.userPlay() == -1) return; } } else { while(true){//1.用戶下棋if(play.userPlay() == -1) return; //2.機器人下棋if(play.robotPlay() == -1) return; } } } //【機器人下棋】 private void sillyRobot(){ //笨機器人 int l, c; while(true){ l = (int)(Math.random() * 3); c = (int)(Math.random() * 3); if(chessBoard[l][c] == ’ ’){chessBoard[l][c] = ’*’;break; } } size++; } private int corner = 2; private void smartRobot(){ //無法戰勝的機器人 if(chessBoard[1][1] == ’ ’){ //搶占中心位置 chessBoard[1][1] = ’*’; size++; return; } //1.判斷是否可以下一個棋子就勝利(不能放在一起同時判斷,否則有可能錯誤最佳位置) for(int i = 0; i < 3; i++){ for(int j = 0; j < 3; j++){if(chessBoard[i][j] == ’ ’){ //【1】如果這個位置沒有棋子,就嘗試下載這個地方,看看是否可以勝; chessBoard[i][j] = ’*’; if(isSuccessful() == -1){ //【1】如果勝的話,就下在這個地方了,返回即可; size++; return ; } else chessBoard[i][j] = ’ ’;} } } for(int i = 0; i < 3; i++){ for(int j = 0; j < 3; j++){//【2】邏輯同【1】if(chessBoard[i][j] == ’ ’){ chessBoard[i][j] = ’O’; //【2】否則嘗試用戶下在這個位置 if(isSuccessful() == 1){ //【2】如果用戶下在這個位置會勝利,就占領它。 chessBoard[i][j] = ’*’; size++; return ; } else chessBoard[i][j] = ’ ’;} } } //2.如果用戶下在了中間的話,就趕緊占兩個四角的位置,才能保證不輸。優先級要比第一個低。用戶沒下在中間也可搶占。 if(corner > 0){ corner--; for(int i = 0; i < 3; i++){ //優先找四邊中沒有用戶棋子的地方下if(i == 1) continue;boolean NoBigO = true;for(int j = 0; j < 3; j++){ if(chessBoard[i][j] == ’O’) NoBigO = false;}for(int j = 0; j < 3 && NoBigO; j++){ if(chessBoard[i][j] == ’ ’){ chessBoard[i][j] = ’*’; size++; return; }} } for(int i = 0; i < 3; i++){for(int j = 0; j < 3; j++){ if(j == 1 || i == 1) continue; if(chessBoard[i][j] == ’ ’){ chessBoard[i][j] = ’*’; size++; return; }} } } //end if //3.判斷是否可以下一個棋子,從而再下一步可以勝利(不能放在一起判斷) for(int i = 0; i < 3; i++){ for(int j = 0; j < 3; j++){if(chessBoard[i][j] == ’ ’){ chessBoard[i][j] = ’*’; if(willBeSuccessful(-1)){ size++; return; } else chessBoard[i][j] = ’ ’;} } } for(int i = 0; i < 3; i++){ for(int j = 0; j < 3; j++){if(chessBoard[i][j] == ’ ’){ chessBoard[i][j] = ’O’; if (willBeSuccessful(1)) { chessBoard[i][j] = ’*’; size++; return; } else chessBoard[i][j] = ’ ’;} } } sillyRobot(); } //【打印棋盤】 private void printChessBroad(){ System.out.println('nnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnn'); //模擬清屏 System.out.println('┌───┬───┬───┐'); System.out.println('│ ' + chessBoard[0][0] + ' │ ' + chessBoard[0][1] + ' │ ' + chessBoard[0][2] + ' │'); System.out.println('├───┼───┼───┤'); System.out.println('│ ' + chessBoard[1][0] + ' │ ' + chessBoard[1][1] + ' │ ' + chessBoard[1][2] + ' │'); System.out.println('├───┼───┼───┤'); System.out.println('│ ' + chessBoard[2][0] + ' │ ' + chessBoard[2][1] + ' │ ' + chessBoard[2][2] + ' │'); System.out.println('└───┴───┴───┘'); } //【判斷成功邏輯】 private enum Choice{ LINE, //行 COLUMN, //列 RIGHT_DIAGONAL, //右對角線 LEFT_DIAGONAL; //左對角線 } private int calculate(Choice choice, int i){ //計算行、列、對角線是否連成一條線 switch (choice){ case LINE:return chessBoard[i][0] + chessBoard[i][1] + chessBoard[i][2]; case COLUMN:return chessBoard[0][i] + chessBoard[1][i] + chessBoard[2][i]; case RIGHT_DIAGONAL:return chessBoard[0][0] + chessBoard[1][1] + chessBoard[2][2]; case LEFT_DIAGONAL:return chessBoard[0][2] + chessBoard[1][1] + chessBoard[2][0]; } return 0; } private int isSuccessful(){ /* 返回-1系統勝;返回1用戶勝;返回0表示繼續下棋。 系統勝:126 == ’*’ + ’*’ + ’*’ 用戶勝:237 == ’O’ + ’O’ + ’O’ */ for(int i = 0; i < 3; i++){ if(calculate(Choice.LINE, i) == 237 || calculate(Choice.COLUMN, i) == 237)return 1; if(calculate(Choice.LINE, i) == 126 || calculate(Choice.COLUMN, i) == 126)return -1; } if(calculate(Choice.LEFT_DIAGONAL, 0) == 237 || calculate(Choice.RIGHT_DIAGONAL, 0) == 237) return 1; if(calculate(Choice.LEFT_DIAGONAL, 0) == 126 || calculate(Choice.RIGHT_DIAGONAL, 0) == 126) return -1; return 0; //繼續下棋 } private boolean willBeSuccessful(int who){ //who:-1表示判斷機器人的,+1表示判斷用戶的。 //如果行、列、對角線有2個相同棋子的個數,則將會勝, //190 == 2 * ’O’ + ’ ’ //116 == 2 * ’*’ + ’ ’ int n = 0; int s = (who == 1) ? 190 : 116; //用戶or機器人要計算的值 for(int i = 0; i < 3; i++){ if(calculate(Choice.LINE, i) == s)n++; if(calculate(Choice.COLUMN, i) == s)n++; } //因為中心一定會被占的,所以就不用判斷對角線了 return n > 1; }}

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

標簽: Java
相關文章:
主站蜘蛛池模板: 窖井盖锯圆机_锯圆机金刚石锯片-无锡茂达金刚石有限公司 | 变位机,焊接变位机,焊接变位器,小型变位机,小型焊接变位机-济南上弘机电设备有限公司 | 山东锐智科电检测仪器有限公司_超声波测厚仪,涂层测厚仪,里氏硬度计,电火花检漏仪,地下管线探测仪 | 杭州中策电线|中策电缆|中策电线|杭州中策电缆|杭州中策电缆永通集团有限公司 | 食品级焦亚硫酸钠_工业级焦亚硫酸钠_焦亚硫酸钠-潍坊邦华化工有限公司 | 全自动实验室洗瓶机,移液管|培养皿|进样瓶清洗机,清洗剂-广州摩特伟希尔机械设备有限责任公司 | 工控机-工业平板电脑-研华工控机-研越无风扇嵌入式box工控机 | 杭州实验室尾气处理_实验台_实验室家具_杭州秋叶实验设备有限公司 | 胶水,胶粘剂,AB胶,环氧胶,UV胶水,高温胶,快干胶,密封胶,结构胶,电子胶,厌氧胶,高温胶水,电子胶水-东莞聚力-聚厉胶粘 | 新疆十佳旅行社_新疆旅游报价_新疆自驾跟团游-新疆中西部国际旅行社 | 工程管道/塑料管材/pvc排水管/ppr给水管/pe双壁波纹管等品牌管材批发厂家-河南洁尔康建材 | 真石漆,山东真石漆,真石漆厂家,真石漆价格-山东新佳涂料有限公司 | 包塑软管|金属软管|包塑金属软管-闵彬管业 | YAGEO国巨电容|贴片电阻|电容价格|三星代理商-深圳市巨优电子有限公司 | 红酒招商加盟-葡萄酒加盟-进口红酒代理-青岛枞木酒业有限公司 | 建筑消防设施检测系统检测箱-电梯**检测仪器箱-北京宇成伟业科技有限责任公司 | 工业淬火油烟净化器,北京油烟净化器厂家,热处理油烟净化器-北京众鑫百科 | 东莞市海宝机械有限公司-不锈钢分选机-硅胶橡胶-生活垃圾-涡电流-静电-金属-矿石分选机 | 山楂片_雪花_迷你山楂片_山楂条饼厂家-青州市丰源食品厂 | PVC地板|PVC塑胶地板|PVC地板厂家|地板胶|防静电地板-无锡腾方装饰材料有限公司-咨询热线:4008-798-128 | EDLC超级法拉电容器_LIC锂离子超级电容_超级电容模组_软包单体电容电池_轴向薄膜电力电容器_深圳佳名兴电容有限公司_JMX专注中高端品牌电容生产厂家 | 大功率金属激光焊接机价格_不锈钢汽车配件|光纤自动激光焊接机设备-东莞市正信激光科技有限公司 定制奶茶纸杯_定制豆浆杯_广东纸杯厂_[绿保佳]一家专业生产纸杯碗的厂家 | 传爱自考网_传爱自学考试网 | 世界箱包品牌十大排名,女包小众轻奢品牌推荐200元左右,男包十大奢侈品牌排行榜双肩,学生拉杆箱什么品牌好质量好 - Gouwu3.com | 电动高尔夫球车|电动观光车|电动巡逻车|电动越野车厂家-绿友机械集团股份有限公司 | 无线遥控更衣吊篮_IC卡更衣吊篮_电动更衣吊篮配件_煤矿更衣吊篮-力得电子 | 贵州科比特-防雷公司厂家提供贵州防雷工程,防雷检测,防雷接地,防雷设备价格,防雷产品报价服务-贵州防雷检测公司 | 长沙发电机-湖南发电机-柴油发电机供应厂家-长沙明邦智能科技 | 杭州公司变更法人-代理记账收费价格-公司注销代办_杭州福道财务管理咨询有限公司 | 巨野月嫂-家政公司-巨野县红墙安康母婴护理中心 | 标策网-专注公司商业知识服务、助力企业发展 | 智能型高压核相仪-自动开口闪点测试仪-QJ41A电雷管测试仪|上海妙定 | 洛阳装修公司-洛阳整装一站式品牌-福尚云宅装饰 | 消泡剂-水处理消泡剂-涂料消泡剂-切削液消泡剂价格-东莞德丰消泡剂厂家 | 云南标线|昆明划线|道路标线|交通标线-就选云南云路施工公司-云南云路科技有限公司 | 活性炭厂家-蜂窝活性炭-粉状/柱状/果壳/椰壳活性炭-大千净化-活性炭 | 湖南印刷厂|长沙印刷公司|画册印刷|挂历印刷|台历印刷|杂志印刷-乐成印刷 | 螺旋丝杆升降机-SWL蜗轮-滚珠丝杆升降机厂家-山东明泰传动机械有限公司 | 找培训机构_找学习课程_励普教育 | 压力喷雾干燥机,喷雾干燥设备,柱塞隔膜泵-无锡市闻华干燥设备有限公司 | 乐之康护 - 专业护工服务平台,提供医院陪护-居家照护-居家康复 |