import java.util.Arrays;
/*"20 78 9 22 34 44"
* 对一个字符串中的数进行排序
* 思路:如何获取到这个字符串中的这些需要排序的数值?
* 发现这个字符串其实都是空格进行分割的
* 将大字符串转化为小字符串
* 再将小字符串转化为数字,再进行排序
*/
public class IntegerDemo {
public static void main(String[] args) {
String str="20 78 9 22 34 44";
System.out.println("排序之前:"+str);
str=sortStringNumber(str);
System.out.println("排序之后:"+str);
}
private static String sortStringNumber(String str) {
// TODO Auto-generated method stub
//1.将字符串变为字符串数组
String[] str_arr=stringToArray(str);
//2.将字符串数组变成int数组
int[] num_arr=toIntArray(str_arr);
//3.对int数组进行排序
mySortArray(num_arr);
//4.将排序后的int数组变成字符串。
String temp=arrayToString(num_arr);
return temp;
}
private static String arrayToString(int[] num_arr) {
// TODO Auto-generated method stub
StringBuilder sb=new StringBuilder();
for(int x=0;x<num_arr.length;x++){
if(x!=num_arr.length-1){
sb.append(num_arr[x]+" ");
}else{
sb.append(num_arr[x]);
}
}
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[] arr=new int[str_arr.length];
for(int i=0;i<arr.length;i++){
arr[i]=Integer.parseInt(str_arr[i]);
}
return arr;
}
private static String[] stringToArray(String str) {
// TODO Auto-generated method stub
String[] str_arr=str.split(" ");
return str_arr;
}
}