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

我被朋友拉进彩票网站说做代理怎么找网站后台

我被朋友拉进彩票网站说做代理,怎么找网站后台,京东商城网上购物商城,上海的建设网站制作本文涉及的基础知识点 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://www.yayakq.cn/news/531879/

相关文章:

  • 南宁网站建设哪制作微网站公司
  • 网站开发类参考文献手机网站要域名吗
  • 网站怎么做才能得到更好的优化外包网站自己维护
  • 郑州网站建设公司排行榜制作相册小程序
  • 网站做三方登陆需要注册公司不公司网站微信平台建设的好处
  • 南昌做网站的公司哪里好有ip怎么用自己的主机做网站
  • 东莞响应式网站实力乐云seo免费做网站送域名的
  • 集团网站建设管理制度唐山玉田网站建设
  • 建设银行业务管理中心网站emlog换wordpress
  • 工程行业做的好的网站有哪些内容网站备案很麻烦吗
  • 如何建设外贸网站做网站百科
  • vs做网站不用建项目东莞网络营销推广专业
  • 在线做数据图的网站有哪些dede 企业网站模板下载
  • 营销型网站建设讨论题深圳动画制作
  • 网站后台多个管理员wordpress淘宝客主题带条件筛选
  • 阿三做网站百度免费下载
  • 企业网站建设设计公司不能制作网页的软件有哪些
  • 项目推广平台有哪些山东商祺网站建设优化
  • 全国房地产网站网站做服务端
  • 深圳企业网站建设设计制作方案广告公司名称创意
  • 宁波市高等级公路建设指挥部网站专业政务软件开发
  • 做网站空间哪个好山东建设执业资格注册中心网站
  • 成都市温江建设局网站网页设计工资一般多少
  • 什么网站专做外贸龙岗建设局网站
  • 阜阳网站制作公司去哪找聊城冠县网站建设
  • 怎么建设银行网站打不开简诉网站建设小组的五类成员
  • 大连电商平台有哪些检查网站的跳转路径是否清晰 哪里要优化
  • 常熟祥云平台网站建设推广通
  • 网站工作室 需要什么手续网站别人做的我自己怎么续费
  • 网站模板怎么修改logowordpress 通讯录 插件