news 2026/6/10 18:52:45

D.二分查找-二分答案-求最大——2576. 求出最多标记下标

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
D.二分查找-二分答案-求最大——2576. 求出最多标记下标

题目链接:2576. 求出最多标记下标(中等)

算法原理:

解法一:排序+双指针+贪心

33ms击败79.27%

时间复杂度O(Nlogn)

首先我们思考一件事情:当一个大的数遇到一堆小的数时,在同样满足2×小的数≤大的数的情况下,咱们选这些小的数中偏小的还是偏大的?那肯定选偏大的啊!因为偏小的可能还能与后续大的数再凑一对,这贪心的思想就来了

①我们要找大的数和小的数就要先排序

②从中间劈开,分别找满足题述条件的2*nums[i] <= nums[j]的数

如果当前的大数能跟前面小的数匹配上,ret+=2,left和right同时往后走

如果匹配不上,说明当前大数小了,要right往后走再继续匹配

解法二:二分查找

35ms击败43.90%

时间复杂度O(Nlogn)

①目标变量:对数

②目标条件:对数最多

③转换逻辑:在mid对的情况下能否满足2 * nums[i] <= nums[j]的条件

具体步骤:

①确定边界:

left:0,最少0对

right:n/2,n为数组长度,最多时,所有数都能组成一对

②确定二分模型:

由于要找最大对数,因此采用最右端点模型,如果没有mid对,说明mid太大了,属于最右端点的右边,需要返回true,缩小mid,向左调整

③check方法设计:判断方法跟解法一类似,都是贪心的思想,但不完全相同,如果数组长度为10,我们在找3对时,只需判断3个最大元素和3个最小元素能否配对即可,如果这都没有3对,那就更不可能再凑3对了

Java代码:

class Solution { //解法一:排序+双指针+贪心 public int maxNumOfMarkedIndices(int[] nums) { Arrays.sort(nums); int n=nums.length; int left=0,right=(n+1)/2; int ret=0; while(left<n/2&&right<n){ if(2*nums[left]<=nums[right]){ ret+=2; left++;right++; }else right++; } return ret; } }
class Solution { //解法二:二分查找 public int maxNumOfMarkedIndices(int[] nums) { Arrays.sort(nums); int n=nums.length; int left=0,right=n/2; int ret=0; while(left<right){ int mid=left+(right-left+1)/2; if(check(mid,nums)) right=mid-1; else left=mid; } return left*2; } //如果不能找到mid对则说明mid太大了,返回true,需要向左调整 private boolean check(int mid,int[] nums){ //0对一定可行,无需向更小调整 if(mid==0) return false; int n=nums.length; //贪心验证:前mid个最小元素配对最后mid个最大元素 for(int i=0;i<mid;i++) //有一个不满足,mid对就达不到 if(2*nums[i]>nums[n-mid+i]) return true; return false; } }
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/10 9:42:12

Docker国产化落地全攻略:从麒麟V10适配到海光CPU性能调优的7个关键步骤

第一章&#xff1a;Docker国产化落地的战略意义与技术全景在信创产业加速推进的背景下&#xff0c;Docker作为容器技术的事实标准&#xff0c;其国产化落地已超越单纯工具替代范畴&#xff0c;成为构建自主可控云原生基础设施的关键支点。从操作系统内核适配、国产CPU指令集兼容…

作者头像 李华
网站建设 2026/6/10 9:47:32

大模型智能客服架构实战:从AI辅助开发到生产环境部署

背景痛点&#xff1a;传统客服的三大“老大难” 去年双十一&#xff0c;我们老系统被 12w 并发直接打挂&#xff1a;CPU 飙到 90%&#xff0c;平均响应 3.8 s&#xff0c;意图识别准确率只剩 62%。复盘下来&#xff0c;问题集中在三点&#xff1a; 动态上下文处理 规则引擎靠正…

作者头像 李华
网站建设 2026/6/9 23:48:51

3个技巧突破网盘限速:直链下载技术全平台实战指南

3个技巧突破网盘限速&#xff1a;直链下载技术全平台实战指南 【免费下载链接】Online-disk-direct-link-download-assistant 可以获取网盘文件真实下载地址。基于【网盘直链下载助手】修改&#xff08;改自6.1.4版本&#xff09; &#xff0c;自用&#xff0c;去推广&#xff…

作者头像 李华
网站建设 2026/6/10 9:44:53

清华大学智能客服背后的Coze智能体:技术实现与生产环境优化指南

清华大学智能客服背后的Coze智能体&#xff1a;技术实现与生产环境优化指南 摘要&#xff1a;本文深入解析清华大学智能客服系统采用的Coze智能体技术架构&#xff0c;针对高并发场景下的响应延迟和意图识别准确率问题&#xff0c;提出基于多轮对话状态管理和动态负载均衡的优化…

作者头像 李华