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

Leetcode 2824. 统计和小于目标的下标对数目

2824. 统计和小于目标的下标对数目

2824. 统计和小于目标的下标对数目

  • 一、题目描述
  • 二、我的想法

一、题目描述

给你一个下标从 0 开始长度为 n 的整数数组 nums 和一个整数 target ,请你返回满足 0 <= i < j < n 且 nums[i] + nums[j] < target 的下标对 (i, j) 的数目。

示例 1:

输入:nums = [-1,1,2,3,1], target = 2
输出:3
解释:总共有 3 个下标对满足题目描述:
(0, 1) ,0 < 1 且 nums[0] + nums[1] = 0 < target
(0, 2) ,0 < 2 且 nums[0] + nums[2] = 1 < target
(0, 4) ,0 < 4 且 nums[0] + nums[4] = 0 < target
注意 (0, 3) 不计入答案因为 nums[0] + nums[3] 不是严格小于 target 。

示例 2:

输入:nums = [-6,2,5,-2,-7,-1,3], target = -2
输出:10
解释:总共有 10 个下标对满足题目描述:
(0, 1) ,0 < 1 且 nums[0] + nums[1] = -4 < target
(0, 3) ,0 < 3 且 nums[0] + nums[3] = -8 < target
(0, 4) ,0 < 4 且 nums[0] + nums[4] = -13 < target
(0, 5) ,0 < 5 且 nums[0] + nums[5] = -7 < target
(0, 6) ,0 < 6 且 nums[0] + nums[6] = -3 < target
(1, 4) ,1 < 4 且 nums[1] + nums[4] = -5 < target
(3, 4) ,3 < 4 且 nums[3] + nums[4] = -9 < target
(3, 5) ,3 < 5 且 nums[3] + nums[5] = -3 < target
(4, 5) ,4 < 5 且 nums[4] + nums[5] = -8 < target
(4, 6) ,4 < 6 且 nums[4] + nums[6] = -4 < target

提示:

  • 1 <= nums.length == n <= 50
  • -50 <= nums[i], target <= 50

二、我的想法

与两数之和类似。

  1. 可以将数组先排个序,因为只要求返回最后的数量,而不是具体的下标。
  2. 使用双指针,一个 left 指向最开始的位置,一个 right 指向末尾。再加上一个变量 count 用来记录数量。
  3. 使用循环。因为数组被排序排好了
    (1)如果 left 指针指向的元素加上 right 指向的元素和大于等于 target,那说明最大的数太大了,往左移看看有没有小一点的能满足条件的数;
    (2)如果 left 指针指向的元素加上 right 指向的元素和小于 target,满足条件,那说明 right 左边的数加上 left 指向的元素的和全都小于 target ,count 加上 right - left,把这些全都加上,left 就可以向右移了。
  4. 等 left 大于等于 right 的时候就可以结束循环,最后返回 count 作为结果。
class Solution:def countPairs(self, nums: List[int], target: int) -> int:nums.sort()numsLen = len(nums)left = 0right = numsLen - 1count = 0while left < right:if nums[left] + nums[right] >= target:right -= 1else:count += right - leftleft += 1return count

相关文章:

  • 北京网站建设多少钱?
  • 辽宁网页制作哪家好_网站建设
  • 高端品牌网站建设_汉中网站制作
  • 04 ES6中对象的简写
  • 深入理解PHP中的异常处理与错误日志记录
  • 关于大数据技术栈的一些总结
  • go使用gjson操作json数据
  • C++与lua联合编程
  • Inconsistent Query Results Based on Output Fields Selection in Milvus Dashboard
  • leetcode 106. 从中序与后序遍历序列构造二叉树
  • 深入分析 Android ContentProvider (三)
  • windows11 ,ubuntu20.04双系统,ubuntu没有wifi的解决方式
  • LeetCode-day20-2850. 将石头分散到网格图的最少移动次数
  • MongoDB - 数组更新操作符:$、$[]、$pop、$pull、$push、$each、$sort、$slice、$position
  • C# 时间、空间复杂度
  • STM32自己从零开始实操10:PCB全过程
  • rce漏洞-ctfshow(50-70)
  • 如何开启或者关闭 Windows 安全登录?
  • php的引用
  • canvas绘制圆角头像
  • echarts的各种常用效果展示
  • es6--symbol
  • gf框架之分页模块(五) - 自定义分页
  • iOS仿今日头条、壁纸应用、筛选分类、三方微博、颜色填充等源码
  • Js基础——数据类型之Null和Undefined
  • k8s如何管理Pod
  • Python实现BT种子转化为磁力链接【实战】
  • rabbitmq延迟消息示例
  • React 快速上手 - 06 容器组件、展示组件、操作组件
  • React 快速上手 - 07 前端路由 react-router
  • React系列之 Redux 架构模式
  • Tornado学习笔记(1)
  • 包装类对象
  • 观察者模式实现非直接耦合
  • 开源地图数据可视化库——mapnik
  • 使用SAX解析XML
  • 原生js练习题---第五课
  • FaaS 的简单实践
  • 格斗健身潮牌24KiCK获近千万Pre-A轮融资,用户留存高达9个月 ...
  • 通过调用文摘列表API获取文摘
  • ​如何使用ArcGIS Pro制作渐变河流效果
  • # Spring Cloud Alibaba Nacos_配置中心与服务发现(四)
  • #数学建模# 线性规划问题的Matlab求解
  • (Java入门)抽象类,接口,内部类
  • (二十一)devops持续集成开发——使用jenkins的Docker Pipeline插件完成docker项目的pipeline流水线发布
  • (附源码)springboot助农电商系统 毕业设计 081919
  • (附源码)ssm经济信息门户网站 毕业设计 141634
  • (一)springboot2.7.6集成activit5.23.0之集成引擎
  • (已解决)报错:Could not load the Qt platform plugin “xcb“
  • (原創) 未来三学期想要修的课 (日記)
  • (转载)微软数据挖掘算法:Microsoft 时序算法(5)
  • .L0CK3D来袭:如何保护您的数据免受致命攻击
  • .mysql secret在哪_MySQL如何使用索引
  • .Net Remoting(分离服务程序实现) - Part.3
  • .net web项目 调用webService
  • .NET/C# 使窗口永不获得焦点
  • .NetCore实践篇:分布式监控Zipkin持久化之殇
  • @ModelAttribute注解使用