Java:连接 String-Int 数组并使用数组寻找可能性

标签 java arrays

我最近开始学习数组,需要各位高手帮忙解决这些问题。 我正在制作一个简单的 Mine 程序,用户在 3x3 网格上从一个方 block 跳到另一个方 block ,直到只剩下一个方 block :有地雷的那个。

int choice;
    String action;
    String square[]={"1A","1B","1C","2D","3E","3F","1G","2H"}; 
    int counter = 0;
    Random random = new Random();
    int mine = random.nextInt(square.length);
    System.out.println(square[mine]);

由于方形数组是一个字符串,所以我将生成的随机地雷从正方形中生成,并且它显示地雷只是为了测试。 但是当用户选择他们想要移动的方 block 时,有很多可能性,例如如果用户选择 square[1],那么有选择 square[0],square[2],...... ., square[7], 等等。因此,我需要帮助通过使用数组来简化这些代码(请记住,我是数组的新手)。

其次,我如何将 String 数组解析为 Int 数组,这样当玩家跳到带有地雷的方格上时,比如说 square[0],然后它必须检查它是否“等于”地雷。 我的代码不起作用:

System.out.println("You will start in the middle of a 5 x 5 square.");
                System.out.println("[" + square[0] + "]\t[" + square[1] + "]\t[" + square[2] + "]");
                System.out.println("[" + square[7] + "]\t[" + character + "]\t[" + square[3] + "]");
                System.out.println("[" + square[6] + "]\t[" + square[5] + "]\t[" + square[4] + "]");
                System.out.print("Hey. Character " + character + ", make your move. ");
                action = (input.readLine());

                if (action.equalsIgnoreCase("1A")) 
                {

                    if (square[0].equals(mine)) 
                    {
                        System.out.println("Sorry. You stepped on a mine!");
                        break;
                    }
                    else 
                    {
                        System.out.println("[" + character + "]\t[" + square[1] + "]\t[" + square[2] + "]");
                        System.out.println("[" + square[7] + "]\t[" + "O" + "]\t[" + square[3] + "]");
                        System.out.println("[" + square[6] + "]\t[" + square[5] + "]\t[" + square[4] + "]");
                        counter++;
                        System.out.print("Make your next move: ");
                        action = input.readLine();
                        if (action.equalsIgnoreCase("1B")) 
                        {
                            if (square[1].equals(mine)) 
                            {
                                System.out.println("Sorry. You stepped on a mine!");
                                break;
                            }
                            else 
                            {
                                System.out.println("[" + "O" + "]\t[" + character + "]\t[" + square[2] + "]");
                                System.out.println("[" + square[7] + "]\t[" + "O" + "]\t[" + square[3] + "]");
                                System.out.println("[" + square[6] + "]\t[" + square[5] + "]\t[" + square[4] + "]");
                                counter++;
                                System.out.print("Make your next move: ");
                                action = input.readLine();
                            }
                        }

显然,“if (square[x].equals(mine))”不起作用,我不知道如何比较 String 和 Int 数组,另一个问题是,如前所述,我的代码时间太长了。这仅仅是因为我正在计算选择每个方 block (8 个中)的可能性以及用户选择之后的方 block (8-1 个中),依此类推,这将是 8 个!阶乘(因为用户从中间的正方形开始,遗漏了八个正方形)。但我不希望 40320 种可能性全部编码,而且我相信你们可以告诉我一种更简单的方法。谢谢!

旁注对于 5x5 正方形,我将如何做?使用字符串数组?还是 Int 数组?还是合并?

最佳答案

是的,有一个更简单的方法。你需要做的是能够回答“坐标 X,Y 处是否有地雷?”的问题。这是通过二维数组完成的,您唯一需要的是在每个点处输入是/否 boolean 值。

boolean[][] minePos = new boolean[5][5];

你这样设置地雷(两个参数都是数字):

minePos[1][1] = true;  //this is 1A
minePos[1][2] = true;  //this is 1B

等等。 Y坐标一直用A,B,C,A需要用1,B用2等,设置为true的地方就是雷的地方。其余都是假的,说明没有我的。当用户想移动到位置xpos,ypos时,你用这个测试那里是否有地雷:

if (minePos[xpos,ypos]) {
    //tell them they were blown up
}
else {
    //you are OK, not blown up
}

如果它们在 xpos,ypos 处是安全的,并且您想将移动限制在它们周围的方格内,那么很容易枚举八种可能的跳跃:

(xpos-1,ypos-1)
(xpos, ypos-1)
(xpos+1, ypos-1) 
(xpos-1,ypos)
(xpos+1, ypos) 
(xpos-1,ypos+1)
(xpos, ypos+1)
(xpos+1, ypos+1) 

等等。他们从八个方向中选择一个,然后您可以根据此确定他们要降落的位置。然后你测试着陆位置是否有地雷。

不清楚您想如何提示用户移动。他们是否表示“我想向上移动一格”?您应该已经知道它们在哪里(在几个变量中),因此给定一个方向很容易计算出它们的着陆点。或者您要让他们输入一个坐标,例如“A1”?然后你需要确保他们输入的坐标与你知道他们所在的坐标相邻。或者您可以显示他们可能移动到的所有可能坐标并让他们选择一个。不管你怎么做,你都会弄清楚目标数字坐标是什么,然后检查那里是否有地雷。

从固定位置的地雷开始,但稍后很容易编写一个将地雷随机放置在 X 和 Y 位置的小循环。像这样:

Random rand = new Random();

for (int count:=1; count<8; count++) {
    int randx = rand.nextInt(5);
    int randy = rand.nextInt(5);
    minePos[randx, randy] = true;
}

这将在随机 x 值(0 到 4)和随机 y 位置(0 到 4)放置 8 个地雷。您可以更改棋盘的大小以及要放置的地雷数量。

关于Java:连接 String-Int 数组并使用数组寻找可能性,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/20341954/

相关文章:

javascript - 删除数组中已存在的较短项目

arrays - 如何在 matlab 中连接数组 'n' 时间?

java - 使用 spring data findAll 从 MongoDB 中检索数据(Example<S> example)

java - 如何在不使用 split 方法或使用数组的情况下将字符串拆分为单词?

c - 如何将数组传递给 C 中的函数(在 Fedora 上)?

arrays - 无法在 TypeScript 中使用 forEach 更改 boolean 数组值

使用c中的结构进行复杂 vector 加法

java - 用Java模拟芝诺悖论的程序

当商小于1时,Java除法不起作用

java - Tomcat JMX CPU 使用百分比