返回介绍

solution / 1100-1199 / 1151.Minimum Swaps to Group All 1's Together / README

发布于 2024-06-17 01:03:23 字数 3896 浏览 0 评论 0 收藏 0

1151. 最少交换次数来组合所有的 1

English Version

题目描述

给出一个二进制数组 data,你需要通过交换位置,将数组中 任何位置 上的 1 组合到一起,并返回所有可能中所需 最少的交换次数

 

示例 1:

输入: data = [1,0,1,0,1]
输出: 1
解释: 
有三种可能的方法可以把所有的 1 组合在一起:
[1,1,1,0,0],交换 1 次;
[0,1,1,1,0],交换 2 次;
[0,0,1,1,1],交换 1 次。
所以最少的交换次数为 1。

示例  2:

输入:data = [0,0,0,1,0]
输出:0
解释: 
由于数组中只有一个 1,所以不需要交换。

示例 3:

输入:data = [1,0,1,0,1,0,0,1,1,0,1]
输出:3
解释:
交换 3 次,一种可行的只用 3 次交换的解决方案是 [0,0,0,0,0,1,1,1,1,1,1]。

示例 4:

输入: data = [1,0,1,0,1,0,1,1,1,0,1,0,0,1,1,1,0,0,1,1,1,0,1,0,1,1,0,0,0,1,1,1,1,0,0,1]
输出: 8

 

提示:

  • 1 <= data.length <= 105
  • data[i] == 0 or 1.

解法

方法一:滑动窗口

我们先统计数组中 $1$ 的个数,记为 $k$。然后我们使用滑动窗口,窗口大小为 $k$,窗口右边界从左向右移动,统计窗口内 $1$ 的个数,记为 $t$。每次移动窗口时,都更新 $t$ 的值,最后窗口右边界移动到数组末尾时,窗口内 $1$ 的个数最多,记为 $mx$。最后答案为 $k - mx$。

时间复杂度 $O(n)$,其中 $n$ 为数组长度。空间复杂度 $O(1)$。

class Solution:
  def minSwaps(self, data: List[int]) -> int:
    k = data.count(1)
    mx = t = sum(data[:k])
    for i in range(k, len(data)):
      t += data[i]
      t -= data[i - k]
      mx = max(mx, t)
    return k - mx
class Solution {
  public int minSwaps(int[] data) {
    int k = 0;
    for (int v : data) {
      k += v;
    }
    int t = 0;
    for (int i = 0; i < k; ++i) {
      t += data[i];
    }
    int mx = t;
    for (int i = k; i < data.length; ++i) {
      t += data[i];
      t -= data[i - k];
      mx = Math.max(mx, t);
    }
    return k - mx;
  }
}
class Solution {
public:
  int minSwaps(vector<int>& data) {
    int k = 0;
    for (int& v : data) {
      k += v;
    }
    int t = 0;
    for (int i = 0; i < k; ++i) {
      t += data[i];
    }
    int mx = t;
    for (int i = k; i < data.size(); ++i) {
      t += data[i];
      t -= data[i - k];
      mx = max(mx, t);
    }
    return k - mx;
  }
};
func minSwaps(data []int) int {
  k := 0
  for _, v := range data {
    k += v
  }
  t := 0
  for _, v := range data[:k] {
    t += v
  }
  mx := t
  for i := k; i < len(data); i++ {
    t += data[i]
    t -= data[i-k]
    mx = max(mx, t)
  }
  return k - mx
}
function minSwaps(data: number[]): number {
  const k = data.reduce((acc, cur) => acc + cur, 0);
  let t = data.slice(0, k).reduce((acc, cur) => acc + cur, 0);
  let mx = t;
  for (let i = k; i < data.length; ++i) {
    t += data[i] - data[i - k];
    mx = Math.max(mx, t);
  }
  return k - mx;
}
public class Solution {
  public int MinSwaps(int[] data) {
    int k = data.Count(x => x == 1);
    int t = data.Take(k).Sum();
    int mx = t;
    for (int i = k; i < data.Length; ++i) {
      t += data[i];
      t -= data[i - k];
      mx = Math.Max(mx, t);
    }
    return k - mx;
  }
}

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。
列表为空,暂无数据
    我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
    原文