1 package cn.itcast.p2.wrapper.test;
2
3 import java.util.Arrays;
4
5 /*
6 * 对一个字符串中的数值进行从小到大的排序。
7 *
8 * "20 78 9 -7 88 36 29"
9 *
10 * 思路:
11 * 1,排序,我很熟。可是我只熟int。
12 * 2,如何获取到这个字符串中的这些需要排序的数值?
13 * 发现这个字符串中其实都是空格来对数值进行分隔的。
14 * 所以就想到用字符串对象的切割方法将大串变成多个小串。
15 * 3,数值最终变成小字符串,怎么变成一个int数呢?
16 * 字符串-->基本类型可以使用包装类。
17 *
18 *
19 */
20 public class WrapperTest {
21 private static final String SPACE_SEPARATOR = " ";
22 public static void main(String[] args) {
23 String numStr = "20 78 9 -7 88 36 29";
24 System.out.println(numStr);
25 numStr = sortStringNumber(numStr);
26 System.out.println(numStr);
27
28 }
29
30 private static String sortStringNumber(String numStr) {
31 // TODO Auto-generated method stub
32 //1,将字符串变成字符串数组。
33 String[] str_arr = stringToArray(numStr);
34 //2,将字符串数组变成int数组。
35 int[] num_arr = toIntArray(str_arr);
36 //3,对int数组排序。
37 mySortArray(num_arr);
38 //4,将排序后的int数组变成字符串。
39 String temp = arrayToString(num_arr);
40
41 return temp;
42 }
43
44 private static String arrayToString(int[] num_arr) {
45 // TODO Auto-generated method stub
46 StringBuilder sBuilder = new StringBuilder();
47 for(int x = 0; x<num_arr.length; x++) {
48 if (x!=num_arr.length-1) {
49 sBuilder.append(num_arr[x]+SPACE_SEPARATOR);
50 } else {
51 sBuilder.append(num_arr[x]);
52
53 }
54 }
55 return sBuilder.toString();
56 }
57
58 private static void mySortArray(int[] num_arr) {
59 // TODO Auto-generated method stub
60 Arrays.sort(num_arr);
61
62 }
63
64 private static int[] toIntArray(String[] str_arr) {
65 // TODO Auto-generated method stub
66
67 int[] arr = new int[str_arr.length];
68 for (int i = 0; i < arr.length; i++) {
69 arr[i] =Integer.parseInt(str_arr[i]);
70 }
71 return arr;
72 }
73
74 /**
75 * @param numStr
76 */
77 private static String[] stringToArray(String numStr) {
78 String[] str_arr = numStr.split(SPACE_SEPARATOR);
79
80 return str_arr;
81 }
82
83 }