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

LeetCode 分类刷题:2529. 正整数和负整数的最大计数

题目

给你一个按 非递减顺序 排列的数组 nums ,返回正整数数目和负整数数目中的最大值。

  • 换句话讲,如果 nums 中正整数的数目是 pos ,而负整数的数目是 neg ,返回 pos 和 neg二者中的最大值。

注意:0 既不是正整数也不是负整数。

示例 1:

输入:nums = [-2,-1,-1,1,2,3]
输出:3
解释:共有 3 个正整数和 3 个负整数。计数得到的最大值是 3 。

示例 2:

输入:nums = [-3,-2,-1,0,0,1,2]
输出:3
解释:共有 2 个正整数和 3 个负整数。计数得到的最大值是 3 。

示例 3:

输入:nums = [5,20,66,1314]
输出:4
解释:共有 4 个正整数和 0 个负整数。计数得到的最大值是 4 。

解析

和 LeetCode 分类刷题:34. 在排序数组中查找元素的第一个和最后一个位置-CSDN博客 思路类似

利用二分查找寻找0元素,采用开区间做法,那么退出循环时:

left指针指向数组中小于0的数的最后一个位置,right指针指向大于等于0的数的第一个位置,然后移动right指针到大于0的数的第一个位置。

此时,小于0的数一共left + 1个,大于0的数一共 len(nums) - 1 - right + 1 = len(nums) - right 个。

再返回二者中的较大者。

答案

class Solution:def maximumCount(self, nums: List[int]) -> int:left, right = -1, len(nums)while left + 1 < right:    # left+1 = right时,开区间(left, right)不包含任何整数mid = (left + right) // 2if nums[mid] < 0:left = midelse:right = mid    # 退出循环时,left指向最后一个负数,right指向第一个非负数while right < len(nums) and nums[right] == 0:    # 跳过0,找到第一个正数right += 1return left + 1 if left + 1 > len(nums) - right else len(nums) - right

复杂度分析

时间复杂度:O(n)

该算法主要由两部分组成:二分查找和线性扫描。二分查找部分用于定位最后一个负数的位置,时间复杂度为 O(log n),其中 n 是数组的长度。线性扫描部分用于跳过连续的零,找到第一个正数,最坏情况下需要遍历整个数组,时间复杂度为 O(n)。

但是实际运行时间还是比遍历数组统计正负数个数的方法快很多。

空间复杂度:O(1)

优化

  • bisect()和bisect_right()等同
  • bisect.bisect和bisect.bisect_right返回大于x的第一个下标(相当于C++中的upper_bound)
  • bisect.bisect_left返回大于等于x的第一个下标(相当于C++中的lower_bound)。
class Solution:def maximumCount(self, nums: List[int]) -> int:neg = bisect_left(nums, 0)pos = len(nums) - bisect_right(nums, 0)return max(neg, pos)# 作者:灵茶山艾府
# 链接:https://leetcode.cn/problems/maximum-count-of-positive-integer-and-negative-integer/
# 来源:力扣(LeetCode)

http://www.dtcms.com/a/347193.html

相关文章:

  • IDEA控制台乱码(Tomcat)解决方法
  • 2-4.Python 编码基础 - 流程控制(判断语句、循环语句、break 语句与 continue 语句)
  • MySQL存储过程详解
  • `strlen` 字符串长度函数
  • GEO优化服务:智能时代的全球竞争新赛道
  • VS Code 中创建和开发 Spring Boot 项目
  • python企微发私信
  • Text2API与Text2SQL深度对比:自然语言驱动的数据交互革命
  • 【40页PPT】数据安全动态数据脱敏解决方案(附下载方式)
  • C/C++ 头文件命名约定
  • stack,queue以及deque的介绍
  • 【Java学习笔记】18.反射与注解的应用
  • [e3nn] 模型部署 | TorchScript JIT | `@compile_mode`装饰器 | Cython
  • TypeScript的构造函数constructor用法理解
  • 深入理解Java虚拟机:JVM高级特性与最佳实践(第3版)第四章知识点问答补充及重新排版
  • 离线优先与冲突解决:ABP vNext + PWA 的边缘同步
  • SQL Server更改日志模式:操作指南与最佳实践!
  • 使用 Certbot 申请 Apache 证书配置棘手问题
  • UAD详解
  • 分库分表系列-核心内容
  • 知识蒸馏 Knowledge Distillation 概率链式法则(Probability Chain Rule)
  • Class42时序模型
  • 深度学习开篇
  • 【通俗易懂】TypeScript 的类型守卫 (Type Guards)作用理解
  • iperf2 vs iperf3:UDP 发包逻辑差异与常见问题
  • [新启航]白光干涉仪与激光干涉仪的区别及应用解析
  • ubuntu 新登录修改root密码
  • 【攻防世界】Web_php_include
  • 力扣热题之动态规划
  • CryptSIPVerifyIndirectData函数分析