我必须得到一个字符串输入和一个整数输入,但输入的顺序应该是,整数首先出现,然后要求用户输入字符串
Scanner in = new Scanner(System.in);
input = in.nextLine();
k = in.nextInt();
in.close();上面的代码运行良好,但如果我首先接受一个整数输入,如下面的代码所示
Scanner in = new Scanner(System.in);
k = in.nextInt();
input = in.nextLine();
in.close();然后抛出java.lang.ArrayIndexOutOfBoundsException。
下面是我的源文件的完整代码:
import java.util.Scanner;公共类StringSwap {
public static void main(String args[]) {
String input;
int k;
Scanner in = new Scanner(System.in);
k = in.nextInt();
input = in.nextLine();
in.close();
int noOfCh = noOfSwapCharacters(input);
originalString(input, noOfCh, k);
}
public static int noOfSwapCharacters(String s) {
char cS[] = s.toCharArray();
int i = 0, postCounter = 0;
while (cS[i] != '\0') {
if (cS[i] != '\0' && cS[i + 1] != '\0') {
cS[cS.length - 1 - postCounter] = '\0';
postCounter++;
}
i++;
}
return postCounter;
}
public static void originalString(String s, int noOfCh, int k) {
int counter = 1, chCounter = 0;
char cArray[] = s.toCharArray();
String post = "";
String pre = "";
String finalString = "";
char temp;
for (int i = 1; i <= k; i++) {
chCounter = 0;
counter = 1;
post = "";
pre = "";
for (int j = 0; j < cArray.length; j++) {
if (counter % 2 == 0 && chCounter <= noOfCh) {
temp = cArray[j];
post = temp + post;
cArray[j] = '\0';
chCounter++;
}
counter++;
}
for (int h = 0; h < cArray.length; h++) {
if (cArray[h] != '\0')
pre = pre + cArray[h];
}
finalString = pre + post;
for (int l = 0; l < finalString.length(); l++) {
cArray[l] = finalString.charAt(l);
}
}
System.out.println(finalString);
}}
请指出我在这里做错了什么。
发布于 2014-04-13 05:06:57
问题出在整数后面的'\n'字符。当您调用nextInt时,扫描程序读取int,但它不使用后面的'\n'字符;nextLine执行此操作。这就是为什么你会得到一个空行,而不是你期望得到的字符串。
假设您的输入包含以下数据:
12345
hello下面是输入缓冲区最初的样子(^表示Scanner读取下一段数据的位置):
1 2 3 4 5 \n h e l l o \n
^在nextInt之后,缓冲区如下所示:
1 2 3 4 5 \n h e l l o \n
^第一个nextLine使用\n,缓冲区如下所示:
1 2 3 4 5 \n h e l l o \n
^现在,nextLine调用将产生预期的结果。因此,要修复程序,您只需在nextInt之后添加另一个对nextLine的调用,并丢弃其结果:
k = in.nextInt();
in.nextLine(); // Discard '\n'
input = in.nextLine();https://stackoverflow.com/questions/23036062
复制相似问题