Java 对一个带空格的字符串进行排序

  • Post author:
  • Post category:java
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 版权协议,转载请附上原文出处链接和本声明。