对于大学作业,我需要生成一个在港口停靠船舶的java系统。该港口有3个码头,每个码头有10个船坞。然而,空间是不同的大小,以容纳不同大小的船舶。小型船舶可适用于小、中、大空间,中型船舶可适用于中、大空间等。
我需要将用户输入并存储到一个二维数组中。用户输入询问用户的名称和大小,然后我需要比较它与‘码头空间’在数组,但我目前不知道如何做到这一点。在某些伪代码中,这就像:
if (userInput == array[arrayValue]) {
//Store ship into array until the user selects to undock the ship
}如何让系统将数组值与用户输入进行比较?如果用户选择了一艘小型船舶,但所有的小船舶空间都被占用了,我如何才能让系统将其放置到一个中等大小的位置?阵列很难!
任何帮助都是很棒的,
提前谢谢!
发布于 2015-03-02 20:37:12
首先,决定如何表示泊位的大小。为了简单起见,我建议使用int数据类型。小泊位可以是大小1、中等2和大型3。
String[] sizes = { "X", "small", "medium", "large" };当您向用户询问船的大小时,如果您选择“输入1表示较小,2为中型,3为大型”,则可以使用
int boatSize = scanner.nextInt();你的二维数组会像这样。
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));
}这应该足以让你开始工作了。
https://stackoverflow.com/questions/28817553
复制相似问题