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

鄂伦春网站建设湖南省网站备案

鄂伦春网站建设,湖南省网站备案,驻马店logo设计公司,2017国外优秀网站模版题目描述 给你一个由 n 个整数组成的数组 nums ,和一个目标值 target 。请你找出并返回满足下述全部条件且不重复的四元组 [nums[a], nums[b], nums[c], nums[d]] (若两个四元组元素一一对应,则认为两个四元组重复): …

题目描述

给你一个由 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.dtcms.com/wzjs/591169.html

相关文章:

  • 中国第八冶金建设公司网站网络推广策划方案模板
  • 建网站要什么数字营销技术应用
  • 计算机网站建设 是什么意思推广普通话的重要性
  • 网站开发文本做网站时背景图片浮动
  • wordpress 静态内容无锡做网站优化哪家好
  • 黑龙江做网站找谁辽宁省建筑工程造价信息网
  • 无锡网站营销公司网页游戏开发入门
  • 个人博客网站建设手机网站默认全屏
  • 网站建设商标保护网页制作的公司怎么注册
  • 商城式网站具备哪些功能吗常州个人网站建设
  • 做苗木行业网站赚钱公司网站后如何更新
  • asp.net 网站安全 检测网页版面布局设计步骤
  • 怎样找人做网站怎样做网站广告
  • 实用网站模板gzip wordpress
  • 外贸网站建设平台哪个好用wordpress建商城
  • 怎么查询网站是什么时候做的金融网站模板源代码
  • 物流网站建设 市场分析公司专业网站建设
  • php网站开发教程培训中国外协加工网免费
  • 互诺科技做网站怎么样新闻类网站建设
  • 荥阳市网站建设集团门户网站建设费用科目
  • c2c商城网站建设费用php 企业网站管理系统
  • 小企业网站建设是怎么做的中国建设银行网站晋阳支行
  • 触屏版网站模板WordPress前端分离
  • vuejs 做网站 性能郑州影视公司有哪些
  • 什么是微网站高端网名好听又有个性
  • 三明市住房和城乡建设局网站企业拍摄宣传片制作
  • 安装网站出现dir厦门网页设计学校
  • 如何建设企业微网站主机如何做服务器建网站
  • 如何用手机做网站吗室内设计公司排名榜
  • 漯河网站推广多少钱中英文双语网站