输入值包含0和1的数组,如何在O(n)实现排序

输入值包含0和1的数组,如何以O(n)时间复杂度,实现排序,0放在前面1放在后面。(任意位置的两个数都可以进行交换),输出交换的次数。

输入:{0,1}

输出:0次

输入:{1,0,1}

输出:1次

输入:{0,1,1,0}

输出:1次

public class Main {

    public static void main(String[] args) {
        Scanner sc = new Scanner(System.in);
        String temp = sc.nextLine();
        temp=temp.trim();
        char []arr= temp.toCharArray();
        int [] sArr=new int[arr.length];
        int j=0;
        for(int i=0;i<arr.length;i++)
        {
            if(arr[i]!=','&&arr[i]!='}'&&arr[i]!='{')
            {
                sArr[j]=arr[i]-'0';
                j++;
            }
        }
        int left=0;

        int right=j-1;
        int swapTime=0;

        while(left<right)
        {
            if(sArr[left]==0)
            {
                left++;

            }
            if(sArr[right]==1)
            {
                right--;

            }
             if(sArr[left]==1&&sArr[right]==0)
            {
                swapTime++;
                left++;
                right--;

            }
        }
        System.out.println(swapTime);
    }

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值