力扣1703.得到连续K个1的最少相邻交换次数

力扣1703.得到连续K个1的最少相邻交换次数

  • 中位数贪心 + 前缀和

    • 设pi = qi - i ,则问题变为所有pi到x的距离和的最小值

    • 同时x应取pi的中位数

    • 因此枚举i作为最左端的1,求最小值即可

    • 推出距离和公式:s[i] + s[i+k] - s[i+k/2]2 - p[i+k/2](k%2)

cpp 复制代码
  class Solution {
  public:
      int minMoves(vector<int>& nums, int k) {
          vector<int> p;
          for(int i=0;i<nums.size();i++)
              if(nums[i])
                  p.push_back(i-p.size());
          int m = p.size(),s[m+1];
          s[0] = 0;
          for(int i=1;i<=m;i++)
              s[i] = s[i-1] + p[i-1];
          int ans = INT_MAX;
          for(int i=0;i<=m-k;i++)
              ans = min(ans,s[i] + s[i+k] - s[i+k/2]*2 - p[i+k/2]*(k%2));
          return ans;
      }
  };
相关推荐
RTC老炮8 小时前
音视频FEC前向纠错算法Reed-Solomon原理分析
网络·算法·架构·音视频·webrtc
郝学胜-神的一滴8 小时前
系统设计:新鲜事系统扩展与优化
java·python·职场和发展·php·软件工程·软件构建
噜噜噜噜鲁先森8 小时前
STL——String类
开发语言·c++·算法
Severus_black8 小时前
算法题C——用队列实现栈/用栈实现队列
c语言·数据结构·算法·链表
谭欣辰8 小时前
详细讲解 C++ 有向无环图(DAG)及拓扑排序
c++·算法·图论
承渊政道8 小时前
【递归、搜索与回溯算法】(掌握记忆化搜索的核心套路)
数据结构·c++·算法·leetcode·macos·动态规划·宽度优先
闻缺陷则喜何志丹9 小时前
【 线性筛 调和级数】P7281 [COCI 2020/2021 #4] Vepar|普及+
c++·算法·洛谷·线性筛·调和级数
zzzsde9 小时前
【Linux】线程概念与控制(1)线程基础与分页式存储管理
linux·运维·服务器·开发语言·算法
穿条秋裤到处跑9 小时前
每日一道leetcode(2026.04.23):等值距离和
算法·leetcode·职场和发展
少许极端9 小时前
算法奇妙屋(四十九)-贡献法
java·算法·leetcode·贡献法