Leetcode - 2009. 使数组连续的最少操作数

文章目录

  • 解析
  • 排序 + 原地去重 + 滑动窗口
  • AC CODE



题目链接:Leetcode - 2009. 使数组连续的最少操作数

在这里插入图片描述


解析

题中所述的连续数组就是一串连续的自然数,想问需要多少次操作能将原数组变为连续的数。
我们排序去重,用逆向思维想能保留的数字数目最多是多少,及用滑动窗口来获取最大数目。


排序 + 原地去重 + 滑动窗口

排序:快速排序。
原地去重:可参考 26. 删除有序数组中的重复项
滑动窗口:以序号i枚举窗口的右边界,也就是让数组中的每一个数都充当一次右边界,然后我们的左边界从0开始,看是否符合窗口大小,不符合就一直推进左边界到合法,然后重新计算窗口内的数字多少,取最大值,此值就是我们能保留的数目的最大值,那么需要修改的最小数目用数组长度减去保留的最多数目。


AC CODE

void quick_sort(int *q, int l, int r){if(l >= r) return;int i = l - 1, j = r + 1, x = q[(l + r) >> 1];while(i < j){do i++; while(q[i] < x);do j--; while(q[j] > x);if(i < j){int k = q[i];q[i] = q[j];q[j] = k;}}quick_sort(q, l, j), quick_sort(q, j + 1, r);
}int dis(int *nums, int numsSize){int j = 0;for(int i = 0; i < numsSize; ++i){if(nums[j] != nums[i])nums[++j] = nums[i];}return j + 1;
}int minOperations(int* nums, int numsSize) {quick_sort(nums, 0, numsSize - 1);int m = dis(nums, numsSize), n = numsSize;int left = 0, ans = 0;for(int i = 0; i < m; ++i){while(nums[i] - n + 1 > nums[left])   left++;ans = fmax(ans, i - left + 1);}return n - ans;
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/601515.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

OpenHarmony实战开发-Ability与ServiceExtensionAbility通信。

介绍 本示例展示通过IDL的方式 和 ohos.rpc 等接口实现了Ability与ServiceExtensionAbility之间的通信。 效果预览 使用说明 1.启动应用后&#xff0c;首页展示城市的天气信息&#xff0c;当前温度每隔5S会刷新一次。 工程目录 entry/src/main/ets/ |---Application |---f…

算力在现实生活中的多方面应用!

算力在现实生活中的应用是多方面的&#xff0c;它已经成为推动现代社会发展的重要力量。 以下是算力在不同领域中的具体应用&#xff1a; 立即免费体验&#xff1a;https://gpumall.com/login?typeregister&sourcecsdn #分布式云服务#算力#GpuMall#GpuMall智算云#训练#…

python ConfigParser:Python 标准库,ini 文件解析器

大家好&#xff01;在进行接口自动化工作时&#xff0c;配置文件是非常常见和重要的一部分。Python 提供了一个强大的标准库——ConfigParser&#xff0c;用于解析和处理 INI 文件。在本文中&#xff0c;我们将介绍如何使用 ConfigParser 来读取和操作 INI 文件&#xff0c;并提…

opencv使用问题记录一二

opencv介绍 opencv是一个计算机视觉处理软件库&#xff0c;拥有强大的功能和高效的性能。 但是由于早期版本的原因&#xff0c;存在一些与目前主流使用不兼容的问题 问题与解决 RGB通道顺序 一般图片处理类库的通道顺序就是RGB&#xff0c;但是opencv的是反过来的&#xf…

嵌入式会越来越卷吗?

当谈及嵌入式系统时&#xff0c;我们探究的不仅是一种科技&#xff0c;更是一个日益多元与普及的趋势。嵌入式系统&#xff0c;作为一种融入更大系统中的计算机硬件和软件&#xff0c;旨在执行特定功能或任务。但这个看似特定的系统概念&#xff0c;却在发展中展现出了惊人的灵…

创建型模式--4.抽象工厂模式【弗兰奇一家】

1. 奔向大海 在海贼世界中&#xff0c;位于水之都的弗兰奇一家是由铁人弗兰奇所领导的以拆船为职业的家族&#xff0c;当然了他们的逆向工程做的也很好&#xff0c;会拆船必然会造船。船是海贼们出海所必备的海上交通工具&#xff0c;它由很多的零件组成&#xff0c;从宏观上看…

fakebook-攻防世界

题目 先目录扫描一下 dirseach 打开flag.php是空白的 访问robots.txt,访问user.php.bak <?php class UserInfo { public $name ""; public $age 0; public $blog ""; public function __construct($name, $age, $blog) { …

软件安全评估之设计评审入门(上)

壹 基础概念 在软件开发生命周期&#xff08;Software Development Life Cycle&#xff0c;简称SDLC&#xff09;中&#xff0c;设计评审&#xff08;Design Review&#xff09;是一个关键的阶段&#xff0c;旨在确保软件设计满足项目需求和目标&#xff0c;并且能够高效、可靠…

工作这么久,你有测试思维了吗?

在如今竞争激烈的职场中&#xff0c;拥有测试思维已成为一个不可或缺的技能。无论你是从事软件开发、项目管理还是市场营销等各行各业&#xff0c;测试思维都能够帮助你更好地解决问题、提高工作效率以及保障质量。然而&#xff0c;工作时间的长短并不代表一个人是否具备测试思…

BC30002 未定义类型“SldWorks.sldworks”

BC30002 未定义类型“SldWorks.sldworks” BC30002 未定义类型“SldWorks.sldworks”问题描述解决办法 BC30002 未定义类型“SldWorks.sldworks” 问题描述 想要使用Visual Studio对Solidworks进行二次开发&#xff0c;但是刚刚开始就已经遇到了问题。 出现使用SLdworks.Sldwo…

Servlet(二)

文章目录 1.ServletConfig1.基本介绍2.应用实例1.DBServlet.java2.web.xml 2.ServletContext1.为什么需要ServletContext2. 基本介绍3.ServletContext 可以做什么4.应用实例一_获取工程相关信息1.ServletContext.java2.web.xml3.结果 5.应用实例二_完成简单网站访问计数器1.Pay…

20240325-1-HMM

HMM 直观理解 马尔可夫链&#xff08;英语&#xff1a;Markov chain&#xff09;&#xff0c;又称离散时间马尔可夫链&#xff08;discrete-time Markov chain&#xff0c;缩写为DTMC&#xff09;&#xff0c;因俄国数学家安德烈马尔可夫&#xff08;俄语&#xff1a;Андре…