将用户输入存储到数组中
Storing User Input into an Array
为了一项大学作业,我需要制作一个 java 系统用于在港口停靠船只。港口有3个码头,每个码头有10个泊位。然而,空间大小不同,以容纳不同大小的船只。小船适合小中大空间,中型船适合中大空间等等
我需要获取用户输入并将其存储到二维数组中。用户输入要求用户提供船舶的名称和大小,然后我需要将其与数组中的 'dock spaces' 进行比较,但我目前不知道如何执行此操作。在某些伪代码中,它会像:
if (userInput == array[arrayValue]) {
//Store ship into array until the user selects to undock the ship
}
如何让系统将数组值与用户输入进行比较?如果用户选择了一艘小船,但所有的小船空间都被占用了,我怎样才能让系统把它放在一个中等大小的地方?数组很难!
任何帮助都会很棒,
提前致谢!
首先,决定如何表示泊位大小。为了简单起见,我建议使用 int
数据类型。小型泊位可以是 1
、中型 2
和大型 3
。
String[] sizes = { "X", "small", "medium", "large" };
当您向用户询问船的尺寸时,如果您给出选择 "Enter 1 for small, 2 for medium, 3 for large",您可以使用
读取输入
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));
}
这应该足以让您入门。
为了一项大学作业,我需要制作一个 java 系统用于在港口停靠船只。港口有3个码头,每个码头有10个泊位。然而,空间大小不同,以容纳不同大小的船只。小船适合小中大空间,中型船适合中大空间等等
我需要获取用户输入并将其存储到二维数组中。用户输入要求用户提供船舶的名称和大小,然后我需要将其与数组中的 'dock spaces' 进行比较,但我目前不知道如何执行此操作。在某些伪代码中,它会像:
if (userInput == array[arrayValue]) {
//Store ship into array until the user selects to undock the ship
}
如何让系统将数组值与用户输入进行比较?如果用户选择了一艘小船,但所有的小船空间都被占用了,我怎样才能让系统把它放在一个中等大小的地方?数组很难!
任何帮助都会很棒,
提前致谢!
首先,决定如何表示泊位大小。为了简单起见,我建议使用 int
数据类型。小型泊位可以是 1
、中型 2
和大型 3
。
String[] sizes = { "X", "small", "medium", "large" };
当您向用户询问船的尺寸时,如果您给出选择 "Enter 1 for small, 2 for medium, 3 for large",您可以使用
读取输入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));
}
这应该足以让您入门。