我正在编写一个菜单来将名称存储到数组中,然后提供添加/删除学生和搜索特定学生的选项,但我似乎无法找到如何设置数组以便我可以使用它在其他选项中,例如,因为我的代码只允许我在使用选项1时输入名称,但是当我选择选项3来搜索数组中的名称时,它不会将这些名称保留在数组中,它只显示对于数组中的每个插槽都为null。
我遇到的另一个问题是如何删除学生,显然如果名称位于数组末尾会非常容易,但如果名称位于中间,我怎么能删除名称,将所有其他名称移到一个插槽中,以便阵列中没有间隙?
import java.util.Scanner;
public class Lab10Ex2 {
public static void main(String[] args) {
int choice = 0;
int[] stringArray = {};
do{
String[] stringarray = new String[20];
System.out.println("----------------MENU---------------");
System.out.println();
System.out.println("1. Add Students");
System.out.println("2. Delete Students");
System.out.println("3. Search for student");
System.out.println("4. Print all Students");
System.out.println("5. exit");
Scanner scanchoice = new Scanner(System.in);
choice = scanchoice.nextInt();
if (choice ==1){
Scanner scannames = new Scanner(System.in);
System.out.println("Please enter the student names into the array");
int i = 0;
for(i = 0; i<stringarray.length; i++){
String temp =scannames.nextLine();
stringarray[i]=temp.toLowerCase();
if(i==(stringarray.length-1)){
System.out.println("successfully filled up array fully");
System.out.println();
}
}
}
if(choice==2){
}
if(choice==3){
for(int p = 0; p<stringarray.length; p++){
System.out.println(stringarray[p]);
}
int x=0;
Scanner scannames1 = new Scanner(System.in);
System.out.println("Enter name of student you want to search for: ");
System.out.println();
String search=scannames1.nextLine();
String searchName=search.toLowerCase();
for(int p=0;p<20;p++){
if(searchName.equals(stringarray[p])){
x=1;
}
else{
x=0;
}
}
if(x==1){
System.out.println("We have a match in our database for "+ searchName);
}
else if (x==0){
System.out.println("No match for "+ searchName);
}
}
if (choice ==4){
System.out.println("List of names:");
for(int p = 0; p<stringarray.length; p++){
System.out.println(stringarray[p]);
}
}
}while(choice!=5);
}
}
答案 0 :(得分:2)
int choice = 0;
int[] stringArray = {};
do{
String[] stringarray = new String[20];
删除int[] stringArray
行(您不在任何地方引用它)。
在循环外移动String[] stringarray
。
至于删除,您必须自己编写代码(将所有已删除的项目移动到数组中的一个),或使用Java提供的一个集合类(而不是本机数组)来处理删除你。
答案 1 :(得分:1)
do{
String[] stringarray = new String[20];
在Do {...}循环的每次迭代中,您将重新创建stringarray变量,从而清除它。如果您将其移到循环外,将保留您的学生条目。
至于删除,如果你不需要使用字符串数组,我建议使用ArrayList。它允许您轻松删除特定条目,而无需担心其他条目。否则,是的,最简单的做法是将所有其他条目移到一个槽中以避免间隙
答案 2 :(得分:0)
以下是更正后的代码:
import java.util.Scanner;
public class Lab10Ex2 {
/**
* @param args
*/
public static void main(String[] args) {
int choice = 0;
int[] stringArray = {};
String[] stringarray = new String[20];
do{
System.out.println("----------------MENU---------------");
System.out.println();
System.out.println("1. Add Students");
System.out.println("2. Delete Students");
System.out.println("3. Search for student");
System.out.println("4. Print all Students");
System.out.println("5. exit");
Scanner scanchoice = new Scanner(System.in);
choice = scanchoice.nextInt();
if (choice ==1){
Scanner scannames = new Scanner(System.in);
System.out.println("Please enter the student names into the array");
System.out.println();
int i = 0;
for(i = 0; i<stringarray.length; i++){
String temp =scannames.nextLine();
stringarray[i]=temp.toLowerCase();
if(i==(stringarray.length-1)){
System.out.println("successfully filled up array fully");
System.out.println();
}
}
}
if(choice==2){
}
if(choice==3){
for(int p = 0; p<stringarray.length; p++){
System.out.println(stringarray[p]);
}
int x=0;
Scanner scannames1 = new Scanner(System.in);
System.out.println("Enter name of student you want to search for: ");
System.out.println();
String search=scannames1.nextLine();
String searchName=search.toLowerCase();
for(int p = 0; p < stringarray.length ;p++){
if(searchName.equals(stringarray[p])){
x=1;
break;
}
else{
x=0;
}
}
if(x==1){
System.out.println("We have a match in our database for "+ searchName);
}
else if (x==0){
System.out.println("No match for "+ searchName);
}
}
if (choice ==4){
System.out.println("List of names:");
for(int p = 0; p<stringarray.length; p++){
System.out.println(stringarray[p]);
System.out.println();
}
}
}while(choice!=5);
}
}
你做错了事:
如果要避免在删除后浪费数组中的空间,请使用ArrayList。如果您使用简单数组绑定此方法,则可以执行以下操作:
将null放在您删除的索引处。使用所有空值创建一个与原始数组大小相同的临时数组。将原始数组中的所有元素复制到临时数组,但跳过null的元素。将原始数组指向新数组。
避免硬编码阵列长度!