所以我试图让我们说int Posx;
持有一个数字,然后当用户浏览菜单时,根据他们选择的内容,将 1、0 或 -1 添加到int Posx
. 添加或减去后,我无法Posx
保留该数字。我正在尝试浏览一个数组,我想保留 2 个整数作为标记,让我知道我目前在数组中关于 x 和 y 的位置。
tl; dr 如何在 do/while 循环中保留一个计数器?
这是问题所在:
//this variable will hold if we found or not the string in the puzzle
boolean found = true;
do {
//Print out the array
for (int x = 0; x < maze.length; x++) {
for (int y = 0; y < maze[0].length; y++) {
System.out.print(maze[x][y]);
}
System.out.println();
}
System.out.printf("You may:\n1) Move up\n2) Move down\n3) Move left\n4) Move right\n0) Quit\nYour Choice (0-4):\n");
int usrAns = sc2.nextInt();
if (usrAns == 0){
System.out.println("Bye!\n");
found = false;
break;
}
//arrays to hold the direction.
int[] movx ={ -1, 0, 0, 1};
int[] movy ={ 0, -1, 1, 0};
//Array to hold the position.
int Posx = 0;
int Posy = 0;
if (usrAns == 1){
if(check(Posx, Posy, maze, movx[1], movy[1])){
System.out.println("Cannot move past cave boundary! Try something else.\n");
continue;
}
else{
Posy = Posy - 1;
System.out.printf("This is Posx %d and Posy %d\n", Posx, Posy);
continue;
}
}
if (usrAns == 2){
if(check(Posx, Posy, maze, movx[2], movy[2])){
System.out.println("Cannot move past cave boundary! Try something else.\n");
continue;
}
else{
Posy= Posy + 1;
System.out.printf("This is Posx %d and Posy %d\n", Posx, Posy);
continue;
}
}
if (usrAns == 3){
if(check(Posx, Posy, maze, movx[0], movy[0])){
System.out.println("Cannot move past cave boundary! Try something else.\n");
continue;
}
else{
Posx = Posx - 1;
System.out.printf("This is Posx %d and Posy %d\n", Posx, Posy);
continue;
}
}
if (usrAns == 4){
if(check(Posx, Posy, maze, movx[3], movy[3])){
System.out.println("Cannot move past cave boundary! Try something else.\n");
continue;
}
else{
Posx =Posx + 1;
System.out.printf("This is Posx %d and Posy %d\n", Posx, Posy);
continue;
}
}
while (usrAns >= 5 || usrAns < 0){
System.out.println("Please enter a number between 0 and 4:\n");
usrAns = sc2.nextInt();
if (usrAns == 0){
System.out.println("Bye!\n");
found = false;
break;
}
}
}while(found);
任何想法、提示或技巧将不胜感激。