java对一个字符串中的数值进行从小到大的排序(注所给字符串只是每个数值之间空一个空格而已)

总结如下:
基础知识不懂之处较多,代码阅读性有待加强,得更加努力才行

package wrapper;//bxtteaxhermethod

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 wrapper;//my way

//		题目:对一个字符串中的数值进行从小到大的排序。

//		 "20 78 9 -7 88 36 29"

/*构造方法如下:
 * 先将该字符串以空格分隔变成字符串数组,然后在遍历调用Integer里的方法将字符串变成int型数值进行比较
 */
public class MyWrapperTest {

	public static void main(String[] args) {
		// TODO Auto-generated method stub
		String str = "20 78 9 -7 88 36 29";
		System.out.println(StringSortNumber(str).toString());
	}

	public static String StringSortNumber(String str) {
		String[] a = StringToArray(str);
		int[] b = new int[a.length];
		for (int i = 0; i < a.length; i++) {// 将数据存储到b数组中
			b[i] = Integer.parseInt(a[i]);
		}
		int temp = 0;// 临时存储变量
		for (int i = 0; i < b.length; i++) {// b数组中的数据进行排序
			for (int j = i + 1; j < b.length; j++) {
				if (b[i] > b[j]) {
					temp = b[j];
					b[j] = b[i];
					b[i] = temp;
				}
			}
		}
		str = "";
		for (int i = 0; i < b.length; i++) {// 将排序后的b数组变成字符串
			str = str + " " + b[i];
		}
		return str;
	}

	public static String[] StringToArray(String str) {//创造符合项目名称,增加可阅读性
		return str.split(" ");
	}

}
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值