这是一道数学题,题目是:输入一个整数如6431345;现在由用户输入要删除数的个数如:4.删除6431345里面4个数 要求是就删除4个数以后这个数要是最小的(还是按原来的顺序排只是把要删除的数从中抽出来)。
这道题我已经做好了,程序功能很全面,没有问题,发在20楼..
import java.io.*;
import java.util.*;
public class ShuXueTI {
public static void main( String[] args ) throws IOException {
BufferedReader bfr = new BufferedReader( new InputStreamReader( System.in ));
System.out.println( "请输入一个整数" );
String str = bfr.readLine();
System.out.println( "请输入你要删除的位数" );
int size = Integer.parseInt( bfr.readLine());
while( size >= str.length() ) {
System.out.println( "删除的位数必数小于数的长度,请重新输入" );
size = Integer.parseInt( bfr.readLine());
}
//到这里都不要解释什么吧!
String result = ""; //存放结果的
List vec = new ArrayList(); //创建一个容器,输入的数字转换后的存放的地方
while( size != 0 ) {
for( int i = 0; i <= size; i++ ) { //这里为什么要小于size看到后面就明白了
vec.add( new Integer(str.charAt(i)));
} //存入Integer对象
result += Collections.min(vec).toString(); //取出容器中最小的,并加到结果的字符串中
int a = Collections.min(vec).toString().indexOf(str); //得到这个最小数的位置
size -= a;
if( a != str.length() -1 ) {
str = str.substring( a + 1 ); //去掉这个数前面的那些字符串,加入if是防出界的
}
else {
str = ""; //这是为下面result += str准备的
}
vec.clear(); //清除vec中的元素
}
result += str; //有可能一次就完成了删除工作,就要加出后面那些字符
System.out.println( result );
}
}
编译通过,运行出现错误如下:
请输入一个整数
958746
请输入你要删除的位数
2
java.lang.StringIndexOutOfBoundsException: String index out of range: 6
at java.lang.String.charAt(String.java:460)
at ShuXueTI.main(ShuXueTI.java:29)
Exception in thread "main"
PS:图中红色的为第二十九行.
[此贴子已经被作者于2006-8-26 8:16:10编辑过]