16-4:字符串练习,对一个字符串中的数值进行从小到大的排序

package cn.itcast.p2.wrapper.test;

import java.util.Arrays;

/*
 * 对一个字符串中的数值进行从小到大的排序。
 *
 * "20 78 9 -7 88 36 29"
 *
 * 思路:
 * 1,排序,我很熟。可是我只熟int。
 * 2,如何获取到这个字符串中的这些需要排序的数值?
 * 发现这个字符串中其实都是空格来对数值进行分隔的。
 * 所以就想到用字符串对象的切割方法将大串变成多个小串。
 * 3,数值最终变成小字符串,怎么变成一个int数呢?
 * 字符串-->基本类型 可以使用包装类。
 *
 *
 */

public class WrapperTest {

    private static final String SPACE_SEPARATOR = " ";
    /**
     * @param args
     */
    public static void main(String[] args) {
        
        String numStr = "20 78 9 -7 88 36 29";
        
        System.out.println(numStr);
        numStr = sortStringNumber(numStr);
        System.out.println(numStr);
        
    }
    /**
     *
     * @param numStr
     * @return
     */
    public static String sortStringNumber(String numStr) {
        
        //1,将字符串变成字符串数组。
        String[] str_arr = stringToArray(numStr);
        
        //2,将字符串数组变成int数组。
        
        int[] num_arr = toIntArray(str_arr);
        
        //3,对int数组排序。
        mySortArray(num_arr);
        
        //4,将排序后的int数组变成字符串。
        
        String temp = arrayToString(num_arr);
        
        return temp;
    }

    public static String arrayToString(int[] num_arr) {
        
        StringBuilder sb = new StringBuilder();
        for(int x = 0; x<num_arr.length; x++){
            if(x!=num_arr.length-1)
                sb.append(num_arr[x]+SPACE_SEPARATOR);
            else
                sb.append(num_arr[x]);
        }
        
        return sb.toString();
    }

    public static void mySortArray(int[] num_arr) {
        
        Arrays.sort(num_arr);
    }

    public static int[] toIntArray(String[] str_arr) {
        
        int[] arr = new int[str_arr.length];
        
        for (int i = 0; i < arr.length; i++) {
            arr[i] = Integer.parseInt(str_arr[i]);
        }
        
        return arr;
    }

    /**
     * @param numStr
     */
    public static String[] stringToArray(String numStr) {
        String[] str_arr = numStr.split(SPACE_SEPARATOR);
        
        
        return str_arr;
    }

}




package cn.itcast.p2.wrapper.test;

import java.util.Arrays;

public class Test {
	public static void main(String []args)
	{
		String numStr = "20 78 9 -7 88 36 29";
		System.out.println(numStr);
		String [] str = String2StringArray(numStr);
		for(String i : str){
			System.out.print(" ****" + i +" ****");
		}
		int [] arr = StringArray2IntArray(str);
		sortArray(arr);
		System.out.println(arr);
		String str2 = intArray2StringArray(arr);
		System.out.println(str2);
		
	}

	private static String intArray2StringArray(int[] arr) {
		StringBuilder sb = new StringBuilder();
		for(int i = 0; i < arr.length; i++){
			if(i != arr.length - 1){
				sb.append(arr[i] + " ");
			}else{
				sb.append(arr[i]);
			}
			System.out.println(sb);
		}
		return sb.toString();
		
	}



	private static void sortArray(int[] arr) {
		Arrays.sort(arr);
		
	}



	private static  int[] StringArray2IntArray(String[] str) {
		int [] intArray = new int[str.length];
		for(int i = 0; i < str.length; i++){
			intArray[i] = Integer.parseInt(str[i]);
		}
		for(int i : intArray){
			System.out.print(" ---" + i +" ---");
		}
		return intArray;
	}



	private static String[] String2StringArray(String numStr) {
		// TODO Auto-generated method stub
		String arr[] = numStr.split(" ");
		for(String i : arr){
			System.out.print(" " + i);
		}
		System.out.println();
		System.out.println(arr.length);
		return arr;
		
	}


}

//1,将字符串变为字符串数组

//2,将字符串数组变成int数组

//3,对int数组进行排序

//4,将int数组变为字符串数组



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值