排序01无序数组

输入乱序的0,1数组,输出一个排序后的数组

输入:

011010

输出:

000111

要求:

只能遍历一次原始数组,并尽量设计出最低时间复杂度的算法


我的思路很简单,借助一个额外的数组,去寻找原始数组中的元素1,找到从新数据的末端开始不断插入1元素。


/**
 * 输入011010乱序0,1数组 输出000111数组
 * @author cui
 *
 */
public class ZeroOneSorter {
public static void main(String[] args) {
	int[] input={0,1,1,0,1,0,1};
	f1(input);
}
public static void f1(int[] input){
	int[] res=new int[input.length];
	int p=res.length-1;
	for (int i = 0; i < input.length; i++) {
		if(input[i]==1){
			res[p--]=1;
		}
	}
	System.out.println(Arrays.toString(res));
}
}



评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值