题目
给定一个二进制数组 nums 和一个整数 k,如果可以翻转最多 k 个 0 ,则返回 数组中连续 1 的最大个数 。
示例
输入:nums = [1,1,1,0,0,0,1,1,1,1,0], K = 2
输出:6
解释:[1,1,1,0,0,1,1,1,1,1,1]
粗体数字从 0 翻转到 1,最长的子数组长度为 6。
输入:nums = [0,0,1,1,0,0,1,1,1,0,1,1,0,0,0,1,1,1,1], K = 3
输出:10
解释:[0,0,1,1,1,1,1,1,1,1,1,1,0,0,0,1,1,1,1]
粗体数字从 0 翻转到 1,最长的子数组长度为 10。
来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/max-consecutive-ones-iii
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。
方法1:滑动窗口
Java实现
class Solution {
public int longestOnes(int[] nums, int k) {
int n = nums.length;
int l = 0, r = 0, sum = 0;
int ans = 0;
while (r < n) {
if (nums[r] != 1) sum++;
r++;
while (sum > k) {
if (nums[l] != 1) sum--;
l++;
}
ans = Math.max(ans, r - l);
}
return ans;
}
}