import java.util.Arrays;
import com.sun.xml.internal.bind.v2.runtime.unmarshaller.XsiNilLoader.Array;
public class WrapperTest {
private static final String SPACE_SEPARATOR=" ";
/*
* 对一个字符串中的数值进行从小到大的排序
*
* “20 78 9 -7 88 36 29”
*
* 思路
* 1 排序 我很熟悉 但我只熟悉 int
* 2 如何获取到这个字符串中的这些需要排序的数值?
* 发现之歌字符串其实是用空格 来对数值进行分割的
* 所以就想到用字符串对象的切割方法 将大串变成多个小串
* 3 数值最终变成小 字符串 怎么变成 int数呢?
* 字符串---->基本类型 可以使用包装类
*
*/
public static void main(String[] args) {
// TODO Auto-generated method stub
String numStr="20 78 9 -7 88 36 29";
System.out.println(numStr);
numStr=sortStringNumber(numStr);
System.out.println(numStr);
}
private static String sortStringNumber(String numStr) {
// TODO Auto-generated method stub
//1、 将字符串变成字符串数组
String [] str_arr=stringToArray(numStr);
//2 将字符串数组变成字符串
int [] num_arr=toIntArray(str_arr);
//3 对数组排序
mySortArray(num_arr);
// 将排序后的数组变字符串
String temp=arryToString(num_arr);
return temp;
}
private static String arryToString(int[] num_arr) {
// TODO Auto-generated method stub
StringBuilder sb=new StringBuilder();
for (int i = 0; i < num_arr.length; i++) {
if(i!=num_arr.length-1)
sb.append(num_arr[i]+ SPACE_SEPARATOR);
else
sb.append(num_arr[i]);
}
return sb.toString();
}
private static void mySortArray(int[] num_arr) {
// TODO Auto-generated method stub
Arrays.sort(num_arr);
}
private static int[] toIntArray(String[] str_arr) {
// TODO Auto-generated method stub
int []num_arr=new int[str_arr.length];
for (int i = 0; i < str_arr.length; i++) {
num_arr[i]=Integer.parseInt(str_arr[i]);
}
return num_arr;
}
private static String[] stringToArray(String numStr) {
// TODO Auto-generated method stub
String []str_arr=numStr.split(SPACE_SEPARATOR+"+");//去除所有空格
return str_arr;
}
}
版权声明:本文为Aseveng原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。