博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
简单的猜数字(JAVA版)
阅读量:7062 次
发布时间:2019-06-28

本文共 2466 字,大约阅读时间需要 8 分钟。

按书上的样例来操作的。

不过,书上提到的BUG,我没有在看下一章时就解决了哈。。

从网上查找的删除数组元素的方法。

其实,将数据结构更改为ARRAYLIST,可能更简单。:)

GameHelper.java

import java.io.*;public class GameHelper {    public String GetUserInput(String prompt) {        String inputLine = null;        System.out.println(prompt + " ");        try {            BufferedReader is = new BufferedReader(new InputStreamReader(System.in));            inputLine = is.readLine();            if (inputLine.length() == 0 )                return null;        } catch (IOException e) {            System.out.println("IOException: " + e);        }        return inputLine;    }}

SimpleDotCom.java

public class SimpleDotCom {    int[] locationCells;    int numOfHits = 0;        public void setLocationCells(int[] locs) {        locationCells = locs;    }        public int[] delLocationCells(int eleInt) {        for(int i = 0; i < locationCells.length; i++) {            if (eleInt == locationCells[i]) {                for(int j = i + 1; j < locationCells.length; j ++) {                    locationCells[i] = locationCells[j];                }            }        }        return locationCells;    }        public String checkYourself(String stringGuess) {        int guess = Integer.parseInt(stringGuess);        String result  = "miss";        for (int cell : locationCells) {            if (guess == cell) {                result = "hit";                numOfHits++;                delLocationCells(guess);                break;            }        }                if (numOfHits == locationCells.length) {            result = "kill";        }        System.out.println(result);        return result;    }}

SimpleDotComTestDrive.java

 

public class SimpleDotComTestDrive {    public static void main(String[] args) {        int numOfGuesses = 0;        GameHelper helper = new GameHelper();                SimpleDotCom theDotCom = new SimpleDotCom();        int randomNum = (int) (Math.random() * 5);                int[] locations = {randomNum, randomNum + 1, randomNum + 2};        theDotCom.setLocationCells(locations);        boolean isAlive = true;                while(isAlive == true) {            String guess = helper.GetUserInput("Enter a number");            String result = theDotCom.checkYourself(guess);            numOfGuesses++;            if(result.equals("kill")) {                isAlive = false;                System.out.println("You took " + numOfGuesses + " guesses.");            }                    }            }}

输出:

转载地址:http://bbnll.baihongyu.com/

你可能感兴趣的文章
LeetCode OJ:Maximal Square(最大矩形)
查看>>
抽象工厂 C++实现
查看>>
[KMP]字符串匹配算法
查看>>
[转] 随机数是骗人的,.Net、Java、C为我作证
查看>>
第一天
查看>>
VUE基础插值表达式
查看>>
如何在mysql客户端即mysql提示符下执行操作系统命令
查看>>
人月神话读后感
查看>>
Learning Agile software Development
查看>>
HDFS原理解析(整体架构,读写操作流程及源代码查看等)
查看>>
“精于算计”与“精于计算”我们应该更偏重哪方面?
查看>>
CAFFE安装(10):Mnist测试(可不做)
查看>>
7.2.7、数组指针的操作
查看>>
SetProp()、GetProp()、RemoveProp() API接口
查看>>
ES6 module模块
查看>>
content management system
查看>>
缓存穿透 缓存雪崩
查看>>
System.gc
查看>>
最小二乘法多项式曲线拟合原理与实现(转)
查看>>
Java NIO 系列教程(转)
查看>>