995. K 连续位的最小翻转次数

995. K 连续位的最小翻转次数

难度困难125收藏分享切换为英文接收动态反馈

在仅包含 0 和 1 的数组 A 中,一次 K 位翻转包括选择一个长度为 K 的(连续)子数组,同时将子数组中的每个 0 更改为 1,而每个 1 更改为 0。

返回所需的 K 位翻转的最小次数,以便数组没有值为 0 的元素。如果不可能,返回 -1。


示例 1:

输入:A = [0,1,0], K = 1输出:2解释:先翻转 A[0],然后翻转 A[2]。

示例 2:

输入:A = [1,1,0], K = 2输出:-1解释:无论我们怎样翻转大小为 2 的子数组,我们都不能使数组变为 [1,1,1]。

示例 3:

输入:A = [0,0,0,1,0,1,1,0], K = 3输出:3解释:翻转 A[0],A[1],A[2]: A变成 [1,1,1,1,0,1,1,0]翻转 A[4],A[5],A[6]: A变成 [1,1,1,1,1,0,0,0]翻转 A[5],A[6],A[7]: A变成 [1,1,1,1,1,1,1,1]


提示:

1 <= A.length <= 30000

1 <= K <= A.length

通过次数7,781

提交次数15,728



思路1:暴力法!模拟翻转!【我也不知道怎么就过了】



思路2,滑动窗口:

你可能感兴趣的:(995. K 连续位的最小翻转次数)