对于大学作业,我需要制作一个用于在港口停靠船只的java系统。该港口有3个码头,每个码头包含10个停靠船只的空间。然而,空间大小不同,以适应不同尺寸的船舶。小型船舶可适用于中小型空间,中型船舶可适应大中型空间等。
我需要获取用户输入并将其存储到2维数组中。用户输入询问用户船的名称和大小,然后我需要将其与数组中的“停靠空间”进行比较,但我目前不知道如何执行此操作。在一些伪代码中,它就像:
if (userInput == array[arrayValue]) {
//Store ship into array until the user selects to undock the ship
}
如何让系统将数组值与用户输入进行比较?如果用户选择了一艘小型船舶,但是所有小型船舶空间都被采用,我该如何让系统将其放入中等大小的位置?阵列很难!
任何帮助都会很棒,
提前致谢!
答案 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));
}
这应该足以让你开始。