其他分享
首页 > 其他分享> > 1004. Max Consecutive Ones III

1004. Max Consecutive Ones III

作者:互联网

This problem can be solved by sliding window:

1. firstly the right point, j, start to move, it it meet a zero, the zeroNum++, which means, we convert one 0 to 1.

2. If we converted too many 0s to 1, we need to move left point, i, forward, until we don't have too many 0s converted.

3. We check whether the current window is larger.

    public int longestOnes(int[] nums, int k) {
        int zeroNum = 0, res =0;
        int i = 0;
        for(int j=0;j<nums.length;j++){
            if(nums[j]==0){
                zeroNum++;   //we convert one 0 to 1
            }
            while(zeroNum>k){
                if(nums[i]==0){
                    zeroNum--;  //we convert 1 to 0 again
                }
                i++;
            }
            res = Math.max(res, j-i+1);  //checker whether the current window is larger
        }
        return res;
    }

 

标签:point,int,Max,move,window,res,zeroNum,1004,III
来源: https://www.cnblogs.com/feiflytech/p/15861129.html