news 2026/4/23 17:45:29

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/4/23 16:14:08

AI模型容器化部署踩坑实录:37个真实报错日志+对应Docker配置修复命令(附2024最新nvidia-docker2兼容矩阵)

第一章&#xff1a;AI模型容器化部署踩坑实录&#xff1a;总览与方法论 AI模型从本地训练环境走向生产服务&#xff0c;容器化已成为事实标准。然而&#xff0c;看似标准化的 Docker 流程&#xff0c;在真实场景中常因模型依赖冲突、GPU 驱动不兼容、权重加载路径异常等细节问题…

作者头像 李华
网站建设 2026/4/23 11:14:57

基于ChatGPT ACP协议的高效对话系统优化实践

1. 背景痛点&#xff1a;原生 ACP 在高并发里“卡”在哪 去年做客服机器人时&#xff0c;我们用官方 SDK 直连 ChatGPT ACP 接口&#xff0c;压测一上 200 并发就雪崩&#xff1a;P99 延迟从 600 ms 飙到 3 s&#xff0c;CPU 空转一半&#xff0c;QPS 却卡在 40 不动。拆开一看…

作者头像 李华
网站建设 2026/4/23 13:04:28

网页设计毕业设计效率提升指南:从重复劳动到自动化工作流

网页设计毕业设计效率提升指南&#xff1a;从重复劳动到自动化工作流 毕业设计最后三个月&#xff0c;我把网页作业拖成了“通宵连续剧”&#xff1a; 手动切图 200 多张&#xff0c;命名从 banner1.png 到 banner_final_final2.png响应式调了 5 轮&#xff0c;每改一次设计稿…

作者头像 李华