将用户输入存储到数组中

时间:2015-03-02 19:07:27

标签: java arrays loops while-loop

对于大学作业,我需要制作一个用于在港口停靠船只的java系统。该港口有3个码头,每个码头包含10个停靠船只的空间。然而,空间大小不同,以适应不同尺寸的船舶。小型船舶可适用于中小型空间,中型船舶可适应大中型空间等。

我需要获取用户输入并将其存储到2维数组中。用户输入询问用户船的名称和大小,然后我需要将其与数组中的“停靠空间”进行比较,但我目前不知道如何执行此操作。在一些伪代码中,它就像:

if (userInput == array[arrayValue]) {
//Store ship into array until the user selects to undock the ship
}

如何让系统将数组值与用户输入进行比较?如果用户选择了一艘小型船舶,但是所有小型船舶空间都被采用,我该如何让系统将其放入中等大小的位置?阵列很难!

任何帮助都会很棒,

提前致谢!

1 个答案:

答案 0 :(得分:0)

首先,决定如何表示泊位尺寸。为简单起见,我建议使用int数据类型。小泊位的大小可以是1,中等2和大3

String[] sizes = { "X", "small", "medium", "large" };

当您向用户询问船只尺寸时,如果您提供选择"输入1表示小型,2表示中型,3表示大型",您可以使用

读取输入
int boatSize = scanner.nextInt();

您的2D数组看起来像这样。

int dockCount = 3;
int berthCount = 10;
int[][] docks = new int[dockCount][berthCount];

以下是如何填充随机大小的泊位。

for (int dock = 0; dock < dockCount; dock++) {
    for (int berth = 0; berth < berthCount; berth++) {
        int size = (int)Math.floor(Math.random() * 3 + 1);
        docks[dock][berth] = size;
    }
}

或者,如果您有预定义的泊位尺寸,您可以创建类似于此的码头。

int[][] docks = {
    { 1, 1, 1, 1, 2, 2, 2, 3, 3, 3 },
    { 1, 1, 1, 1, 1, 1, 2, 2, 3, 3 },
    { 1, 1, 1, 1, 1, 1, 1, 1, 2, 3 }
};

您还需要一个数据结构来存储每个泊位是否已满。

boolean[][] full = new boolean[dockCount][berthCount];

假设以上所有内容,找到合适的泊位将会是这样的。

int dock, berth, size;
for (size = boatSize; size <= 3; size++) {
    boolean found = false;
    for (dock = 0; dock < dockCount; dock++) {
        for (berth = 0; berth < berthCount; berth++) {
            if (!full[dock][berth]) {
                if (size == docks[dock][berth]) {
                    found = full[dock][berth] = true;
                    break;
                }
            }
        }
        if (found) break;
    }
    if (found) break;
}

if (size > 3) {
    System.out.println("No vacancy");
} else {
    System.out.println("Take the " + sizes[size]
        + " berth at dock " + (dock+1) + " space " + (space+1));
}

这应该足以让你开始。