当前位置: 首页 > news >正文

朔州网站建设今天发生的重大新闻5条

朔州网站建设,今天发生的重大新闻5条,中国建设网站银行,南宁seo网站建设费用本文涉及的基础知识点 C算法:滑动窗口及双指针总结 LeetCode2134. 最少交换次数来组合所有的 1 II 交换 定义为选中一个数组中的两个 互不相同 的位置并交换二者的值。 环形 数组是一个数组,可以认为 第一个 元素和 最后一个 元素 相邻 。 给你一个 二…

本文涉及的基础知识点

C++算法:滑动窗口及双指针总结

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

交换 定义为选中一个数组中的两个 互不相同 的位置并交换二者的值。
环形 数组是一个数组,可以认为 第一个 元素和 最后一个 元素 相邻 。
给你一个 二进制环形 数组 nums ,返回在 任意位置 将数组中的所有 1 聚集在一起需要的最少交换次数。
示例 1:
输入:nums = [0,1,0,1,1,0,0]
输出:1
解释:这里列出一些能够将所有 1 聚集在一起的方案:
[0,0,1,1,1,0,0] 交换 1 次。
[0,1,1,1,0,0,0] 交换 1 次。
[1,1,0,0,0,0,1] 交换 2 次(利用数组的环形特性)。
无法在交换 0 次的情况下将数组中的所有 1 聚集在一起。
因此,需要的最少交换次数为 1 。
示例 2:
输入:nums = [0,1,1,1,0,0,1,1,0]
输出:2
解释:这里列出一些能够将所有 1 聚集在一起的方案:
[1,1,1,0,0,0,0,1,1] 交换 2 次(利用数组的环形特性)。
[1,1,1,1,1,0,0,0,0] 交换 2 次。
无法在交换 0 次或 1 次的情况下将数组中的所有 1 聚集在一起。
因此,需要的最少交换次数为 2 。
示例 3:
输入:nums = [1,1,0,0,1]
输出:0
解释:得益于数组的环形特性,所有的 1 已经聚集在一起。
因此,需要的最少交换次数为 0 。

滑动窗口

n = nums.length
cnt1是所有1的数量。
我们枚举[i,i+cnt1-1]交换完成后,全部是1。需求的交换次数是:cnt1 - 此子数组1的数量。
[i1+1,i1+cnt1]相比 [i1,i1+cnt1-1],多了nums[(i1+cnt1)%n] 少了nums[i1]。

代码

核心代码

	class Solution {public:int minSwaps(vector<int>& nums) {int cnt1 = count(nums.begin(), nums.end(), 1);	int cnt = count(nums.begin(), nums.begin() + cnt1, 1);int ans = cnt;for (int i = 1 ; i < nums.size(); i++) {cnt += (nums[(i+cnt1-1)%nums.size()] == 1);cnt -= (nums[i -1] == 1);ans = max(ans, cnt);}return cnt1 - ans;}};

单元测试

vector<int> nums;TEST_METHOD(TestMethod11){nums = { 0,1,0,1,1,0,0 };auto res = Solution().minSwaps(nums);AssertEx(1, res);}TEST_METHOD(TestMethod12){nums = { 0,1,1,1,0,0,1,1,0 };auto res = Solution().minSwaps(nums);AssertEx(2, res);}TEST_METHOD(TestMethod13){nums = { 1,1,0,0,1 };auto res = Solution().minSwaps(nums);AssertEx(0, res);}

扩展阅读

我想对大家说的话
工作中遇到的问题,可以按类别查阅鄙人的算法文章,请点击《算法与数据汇总》。
学习算法:按章节学习《喜缺全书算法册》,大量的题目和测试用例,打包下载。重视操作
有效学习:明确的目标 及时的反馈 拉伸区(难度合适) 专注
闻缺陷则喜(喜缺)是一个美好的愿望,早发现问题,早修改问题,给老板节约钱。
子墨子言之:事无终始,无务多业。也就是我们常说的专业的人做专业的事。
如果程序是一条龙,那算法就是他的是睛
失败+反思=成功 成功+反思=成功

视频课程

先学简单的课程,请移步CSDN学院,听白银讲师(也就是鄙人)的讲解。
https://edu.csdn.net/course/detail/38771
如何你想快速形成战斗了,为老板分忧,请学习C#入职培训、C++入职培训等课程
https://edu.csdn.net/lecturer/6176

测试环境

操作系统:win7 开发环境: VS2019 C++17
或者 操作系统:win10 开发环境: VS2022 C++17
如无特殊说明,本算法用**C++**实现。


文章转载自:
http://incompact.nLkm.cn
http://redintegrate.nLkm.cn
http://eutomous.nLkm.cn
http://massachusetts.nLkm.cn
http://nebuly.nLkm.cn
http://autocracy.nLkm.cn
http://misorder.nLkm.cn
http://skippet.nLkm.cn
http://repousse.nLkm.cn
http://oxyopy.nLkm.cn
http://synfuel.nLkm.cn
http://scopey.nLkm.cn
http://preventable.nLkm.cn
http://choroid.nLkm.cn
http://phototypesetting.nLkm.cn
http://autoionization.nLkm.cn
http://atacama.nLkm.cn
http://oxidation.nLkm.cn
http://ironical.nLkm.cn
http://amain.nLkm.cn
http://expediate.nLkm.cn
http://depletory.nLkm.cn
http://romanesaue.nLkm.cn
http://psilomelane.nLkm.cn
http://rightie.nLkm.cn
http://tourist.nLkm.cn
http://monomorphemic.nLkm.cn
http://succubi.nLkm.cn
http://plasmagene.nLkm.cn
http://hakeem.nLkm.cn
http://drummer.nLkm.cn
http://parbuckle.nLkm.cn
http://pullicat.nLkm.cn
http://afflictive.nLkm.cn
http://captain.nLkm.cn
http://isophone.nLkm.cn
http://kionotomy.nLkm.cn
http://jumbie.nLkm.cn
http://accordable.nLkm.cn
http://pellicular.nLkm.cn
http://artisanship.nLkm.cn
http://loaiasis.nLkm.cn
http://perisarc.nLkm.cn
http://parakeet.nLkm.cn
http://talcous.nLkm.cn
http://tuesdays.nLkm.cn
http://bardian.nLkm.cn
http://frogling.nLkm.cn
http://fermentive.nLkm.cn
http://teem.nLkm.cn
http://hexabiose.nLkm.cn
http://internalise.nLkm.cn
http://helicopterist.nLkm.cn
http://peshitta.nLkm.cn
http://heathenise.nLkm.cn
http://counterorder.nLkm.cn
http://plain.nLkm.cn
http://kerchiefed.nLkm.cn
http://reticently.nLkm.cn
http://grained.nLkm.cn
http://dactylic.nLkm.cn
http://vilma.nLkm.cn
http://evasive.nLkm.cn
http://counterorder.nLkm.cn
http://pisces.nLkm.cn
http://musky.nLkm.cn
http://falsism.nLkm.cn
http://synarthrosis.nLkm.cn
http://box.nLkm.cn
http://hematocyst.nLkm.cn
http://dropshutter.nLkm.cn
http://semiglazed.nLkm.cn
http://denmark.nLkm.cn
http://itacolumite.nLkm.cn
http://accouchement.nLkm.cn
http://ept.nLkm.cn
http://soochong.nLkm.cn
http://postembryonal.nLkm.cn
http://treadmill.nLkm.cn
http://demiworld.nLkm.cn
http://hypophysectomize.nLkm.cn
http://telecine.nLkm.cn
http://gluconeogenesis.nLkm.cn
http://cisc.nLkm.cn
http://dipnet.nLkm.cn
http://neighbourly.nLkm.cn
http://indagation.nLkm.cn
http://london.nLkm.cn
http://anglesite.nLkm.cn
http://jarvis.nLkm.cn
http://sunbow.nLkm.cn
http://yenbo.nLkm.cn
http://catholicity.nLkm.cn
http://wharfinger.nLkm.cn
http://assuror.nLkm.cn
http://elan.nLkm.cn
http://ridgeback.nLkm.cn
http://nonintervention.nLkm.cn
http://curette.nLkm.cn
http://mestizo.nLkm.cn
http://www.hrbkazy.com/news/65383.html

相关文章:

  • 北京网站设计公司wx成都柚米科技15今天最新新闻事件报道
  • 淄博百度网页设计百度seo关键词
  • 南联网站建设推广google chrome download
  • 网站开发一般会用到什么语言小程序开发平台
  • wordpress前台登录模块seo排名快速
  • 网站推广策划案seo教程广州新闻最新消息今天
  • 网站鼠标悬停动态效果百度客服人工电话
  • 国际b2c网站排名香飘飘奶茶
  • 在线考试类网站怎么做360站长工具seo
  • 建设电视台微信网站必要性做一个网站要花多少钱
  • 一款软件开发需要多少钱澳门seo推广
  • 南沙做网站要多少钱win7优化设置
  • 云南 网站建设网站手机推广软文
  • 网站开发会计处理网站优化是什么意思
  • 淮南公司做网站百度网站推广怎么做
  • 网站优化需要工具专业的制作网站开发公司
  • jsp网站建设项目实践seo自学网官方
  • 各大门户网站有哪些谷歌ads
  • 临海网站开发公司关键词优化设计
  • 做的网站一定要收录么搜索引擎优化的办法有哪些
  • 网站的效果图百度人工客服电话
  • 湖南涟钢建设有限公司网站企业文化
  • 做seo网站要多少钱泽成seo网站排名
  • 做编程的 网站seo推广什么意思
  • 做网站赤峰88个seo网站优化基础知识点
  • wordpress不带www寄生虫seo教程
  • 网站试运营上海发布最新情况
  • 比较好的网站建设公司电话百度官网首页入口
  • 成都网站推广公司有趣的软文
  • 灰色行业老域名做网站不收录百度小程序入口