【LeetCode18】四数之和

ops/2025/2/26 20:43:50/

题目描述

给你一个由 n 个整数组成的数组 nums ,和一个目标值 target 。请你找出并返回满足下述全部条件且不重复的四元组 [nums[a], nums[b], nums[c], nums[d]] (若两个四元组元素一一对应,则认为两个四元组重复):

0 <= a, b, c, d < n
a、b、c 和 d 互不相同
nums[a] + nums[b] + nums[c] + nums[d] == target
你可以按 任意顺序 返回答案 。

思路与算法

仍然是排序 + 双指针
不过比三数之和多套一层循环 三数之和

  1. 每次固定一个数 nums[i],作为四元组的第一个元素。(我们应该避免重复处理值相同的元素为四元组的第一个元素,因此,当nums[i]与nums[i-1]相等时,应该跳过。
  2. 使用双指针来查找两个数之和为 target - nums[i] - nums[j],其中 j 是第二层循环的指针。
  3. 如果当前的两个数和小于目标值,则移动左指针增大和;如果和大于目标值,则移动右指针减小和。

代码

class Solution:def fourSum(self, nums: List[int], target: int) -> List[List[int]]:nums.sort() results = []for i in range(len(nums) - 3):# if nums[i] > target:#     break;# 跳过重复的元素if i > 0 and nums[i] == nums[i-1]:continuefor j in range(i+1, len(nums) - 2):# 跳过重复的元素if j > i + 1 and nums[j] == nums[j - 1]:continue# 双指针left, right = j + 1, len(nums) - 1while left < right:four_sum = nums[i] + nums[j] + nums[left] + nums[right]if four_sum == target:results.append([nums[i], nums[j], nums[left], nums[right]])# 可以放大nums[left]同时缩小nums[right]继续找,但应该先避免重复while left < right and nums[left] == nums[left+1]:left += 1while left < right and nums[right] == nums[right-1]:right -= 1# 移动指针,放大nums[left]同时缩小nums[right]left += 1right -= 1elif four_sum < target:left += 1else:right -= 1return results

之前的三数之和题目,target固定为0;且由于数组是升序排列的,当 nums[i] 大于 target(即大于 0)时,必然无法找到满足条件的三元组,因此可以提前退出外层循环。
但在本题中,当 target 为负数时,即使 nums[i](作为四元组的最小值)大于 target,只要后续的数中存在负数,依然有机会构成满足目标值的四元组。
例子:
nums=[1,-2,-5,-4,-3,3,3,5]
target=-11
output:[[-5,-4,-3,1]]
在这种情况下,负数的参与使得和能够小于 target,从而形成有效的解

总结


http://www.ppmy.cn/ops/161494.html

相关文章

Arcmap和ArcgisPro重装及配置迁移

近期要重装一下ArcgisPro&#xff0c;在此记录并作为大家的借鉴 1.备份配置文件&#xff1a;其中Desktop10.8为Arcmap的配置文件 2.通过控制面板卸载&#xff0c;arcpro卸载时间较长&#xff0c;先将语言包等卸载&#xff0c;最后再卸载5G主程序&#xff0c;有些文章会介绍清理…

Github 2025-02-25 Python开源项目日报 Top10

根据Github Trendings的统计,今日(2025-02-25统计)共有10个项目上榜。根据开发语言中项目的数量,汇总情况如下: 开发语言项目数量Python项目10Vue项目1稳定扩散Web UI 创建周期:512 天开发语言:Python协议类型:GNU Affero General Public License v3.0Star数量:117672 个…

【Blender】二、建模篇--08,小狐狸角色建模

这堂课呢 我们来完成本套课程建模片的最后一个模型 小狐狸 这堂课呢 主要想让大家一起走一遍角色建模的一个基本流程 让你以后遇到类似的模型时候有一个基本的建模思路 那我们现在就开始吧 2 00:00:16,830 --> 00:00:24,390 我们还是在我们之前建模马拉松的那个文件里面继…

在Linux上创建一个Docker容器并在其中执行Python脚本

在Linux上创建一个Docker容器并在其中执行Python脚本的过程&#xff0c;涉及多个方面的内容&#xff0c;包括安装Docker、编写Dockerfile、构建镜像、运行容器等。 1. 安装Docker 在Linux上使用Docker之前&#xff0c;你需要确保系统已安装Docker。Docker支持的Linux发行版有…

常用计算机网络命令

命令&#xff1a;ping 用于检测网络连通性&#xff0c;判断目标地址是否可达。 常用参数 -t &#xff1a;持续发送数据包&#xff0c;直到手动停止。-n <count> &#xff1a;发送指定数量的数据包。-l <size> &#xff1a;指定发送的数据包大小。 ping www.exa…

本地部署deepseek大模型后使用c# winform调用(可离线)

介于最近deepseek的大火&#xff0c;我就在想能不能用winform也玩一玩本地部署&#xff0c;于是经过查阅资料&#xff0c;然后了解到ollama部署deepseek,最后用ollama sharp NUGet包来实现winform调用ollama 部署的deepseek。 本项目使用Vs2022和.net 8.0开发&#xff0c;ollam…

ESP32 websocket-client

本文简介 ESP-IDF WebSocket-Client 实验平台 ①ESP-IDF 版本&#xff1a;release/v5.3.2 ③硬件平台&#xff1a;esp32-s3 版权声明 ①作者&#xff1a;coLin ②声明&#xff1a;问题总结&#xff0c;有误解&#xff0c;请联系纠正。 正文 1、基于 esp-idf 如何使用 …

Android Audio实战——音频相关基础概念(附)

Android Audio 开发其实就是媒体源数字化的过程,通过将声波波形信号通过 ADC 转换成计算机支持的二进制的过程叫做音频采样 (Audio Sampling)。采样 (Sampling) 的核心是把连续的模拟信号转换成离散的数字信号。 一、声音的属性 1、响度 (Loudness) 响度是指人类可以感知到的…