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

D.二分查找-基础-2529. 正整数和负整数的最大计数

题目链接:2529. 正整数和负整数的最大计数(简单)

算法原理:

解法:二分查找

模板👇

优选算法-二分:18.在排序数组中查找元素的第一个和最后一个位置

利用题目的按 非递减顺序 排列的条件就可以二分处理了,找到负数的最右端点和正数的最左端点

思路一:将二分查找的值设为定值,间接找到不确定的值

击败100.00%

时间复杂度O(Logn)

目标值定为0,因为0恰好是二段性的节点,因此可以有两种角度看待这个目标值0

①左区间最右端的0:[-5,-3-2-1,0,0,0,0,1,4,5,6]

②右区间最左端的0:[-5,-3-2-1,0,0,0,0,1,4,5,6]

第一次遍历找到 最左端的0 进而找到 最后一个负数 :

二分查找结束后,left和right在0(没有0就在0的右侧),先处理边界情况,看是否全是负数,是0或者正数就正常更新长度即可

第二次遍历找到 最右端的0 进而找到 第一个正数 :

二分查找结束后,left和right在0(没有0就在0的左侧),先处理边界情况,看是否全是正数,是0或者负数就正常更新长度即可

思路二:直接将二分查找的值设为要找的不确定值

击败100.00%

时间复杂度O(Logn)

比思路一好写一些,但是要理解好每一步,这里的if判断是带等号的,因为0不算正数也不算负数,等于0的时候也要相应移动

答疑

Q1:能不能用一次二分就找到最后的负数和第一个正数呢?

能的,比如先找到最后一个负数的位置,然后left右移找到第一个正数的位置,但是不保证时间复杂度一定是logn,因为当数据[-1,0,0,0,0,0,~,0,0,0,2],的时候left一直右移就会将时间复杂度弱化到O(N),所以两次二分还是更稳妥些

Java代码:

class Solution { public int maximumCount(int[] nums) { //利用题目的按 非递减顺序 排列的条件就可以二分处理了 //找到负数的最右端点和正数的最左端点 int n=nums.length; if(n==0) return 0; //利用0来决定二段性:负数 0 正数 //先找最后一个负数(通过最左侧的0来找) int left=0,right=n-1; while(left<right){ int mid=left+(right-left)/2; if(nums[mid]<0) left=mid+1; else right=mid; } //此时在0或者0的右侧(正数) int neg=0; //全是负数 if(nums[left]<0) neg=n; //是0或者正数 else neg=left; //再找第一个正数(通过最右侧的0来找) left=0;right=n-1; while(left<right){ int mid=left+(right-left+1)/2; if(nums[mid]>0) right=mid-1; else left=mid; } //此时在0或者0的左侧 int pos=0; //全是正数 if(nums[left]>0) pos=n; //是0或者负数 else pos=n-(left+1); return Math.max(neg,pos); } }
class Solution { //思路二:直接将二分查找的值设为要找的不确定值 public int maximumCount(int[] nums) { int n=nums.length; if(n==0) return 0; int left=0,right=n-1; //找到负数的最后一个位置 while(left<right){ int mid=left+(right-left+1)/2; if(nums[mid]>=0) right=mid-1; else left=mid; } int neg=nums[left]<0?left+1:0; //找到正数的第一个位置 left=0;right=n-1; while(left<right){ int mid=left+(right-left)/2; if(nums[mid]<=0) left=mid+1; else right=mid; } int pos=nums[left]>0?n-left:0; return Math.max(neg,pos); } }
http://www.jsqmd.com/news/84927/

相关文章:

  • 动态规划在字符串匹配中的艺术:从编辑距离到正则匹配
  • simulink二维查表模块应用案例介绍
  • Go 操作 Redis
  • 12.13 - 岛屿数量 C语言中extern关键字的作用
  • 20亿参数挑战千亿模型:土耳其语专用LLM Kumru-2B改写行业规则
  • torch 操作函数
  • 什么叫范式
  • Qwen3Guard-Gen-0.6B震撼发布:Qwen团队打造新一代多语言安全审核模型,重新定义AI内容风控标准
  • Qwen3-30B-A3B-Thinking-2507-FP8:新一代推理增强大模型重磅发布
  • MachineLearningLM:革新大语言模型上下文学习能力的突破性框架
  • 板栗矮砧密植:水肥一体化系统的铺设要点指南
  • 百度网盘提取码终极解决方案:告别繁琐操作的一键神器
  • 【Java数组】--告别困惑快速掌握数组
  • Flutter 实现一个容器内部元素可平移、缩放和旋转等功能(三)
  • Qwen3-VL-4B-Instruct-FP8:多模态大模型的轻量化革命与技术突破
  • Qwen2.5-VL-3B-Instruct-AWQ:新一代多模态模型的技术突破与应用实践
  • jupyter notebook如何使用虚拟环境?
  • 本地化部署腾讯混元大模型并集成Elasticsearch构建智能检索系统全攻略
  • 004登录功能测试
  • 黑科技软件,确实牛X!
  • 每日三题 6
  • DeepSeek-V2-Chat-0628强势登顶开源模型榜首,三大核心能力改写行业竞争格局
  • 结构体设计艺术:Host侧Tiling数据结构定义详解
  • 14、正则表达式与日志处理全解析
  • 错误处理与异常调试在Ascend C中的艺术:从防御性编程到系统级排查
  • 腾讯云智能体开发平台RAG模型商业化倒计时 核心功能12月10日起正式计费
  • 小米开源MiDashengLM-7B声音大模型:22项测评登顶SOTA,推理效率提升4倍
  • iTerm2 美化
  • HunyuanImage-GGUF模型部署全攻略:从基础配置到轻量化实践
  • 生成PPT的提示词模版