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

来源:互联网 发布:展示柜盘管毛细管算法 编辑:程序博客网 时间:2024/05/16 11:41
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 stubString 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 stubStringBuilder 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 stubArrays.sort(num_arr);}private static int[] toIntArray(String[] str_arr) {// TODO Auto-generated method stubint []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 stubString  []str_arr=numStr.split(SPACE_SEPARATOR+"+");//去除所有空格return str_arr;}}

阅读全文
0 0
原创粉丝点击