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

php mysql的网站开发免费建立个人网站官网

php mysql的网站开发,免费建立个人网站官网,中山好的网站建设公司,wordpress 301重定向Problem: 15. 三数之和 文章目录 题目解题方法复杂度Code 题目 给你一个整数数组 nums ,判断是否存在三元组 [nums[i], nums[j], nums[k]] 满足 i ! j、i ! k 且 j ! k ,同时还满足 nums[i] nums[j] nums[k] 0 。请 你返回所有和为 0 且不重复的三元…

Problem: 15. 三数之和

文章目录

  • 题目
  • 解题方法
  • 复杂度
  • Code

题目

给你一个整数数组 nums ,判断是否存在三元组 [nums[i], nums[j], nums[k]] 满足 i != j、i != k 且 j != k ,同时还满足 nums[i] + nums[j] + nums[k] == 0 。请

你返回所有和为 0 且不重复的三元组。

注意:答案中不可以包含重复的三元组。

示例 1:

输入:nums = [-1,0,1,2,-1,-4]
输出:[[-1,-1,2],[-1,0,1]]
解释:
nums[0] + nums[1] + nums[2] = (-1) + 0 + 1 = 0 。
nums[1] + nums[2] + nums[4] = 0 + 1 + (-1) = 0 。
nums[0] + nums[3] + nums[4] = (-1) + 2 + (-1) = 0 。
不同的三元组是 [-1,0,1] 和 [-1,-1,2] 。
注意,输出的顺序和三元组的顺序并不重要。
示例 2:

输入:nums = [0,1,1]
输出:[]
解释:唯一可能的三元组和不为 0 。
示例 3:

输入:nums = [0,0,0]
输出:[[0,0,0]]
解释:唯一可能的三元组和为 0 。

提示:

3 <= nums.length <= 3000
− 1 0 5 -10^5 105 <= nums[i] <= 1 0 5 10^5 105

解题方法

我们先考虑最朴实的解法,我们可以遍历三次数组,计算这三次的和,判断是否为零,再通过集合去重,但是这样的时间复杂度是 o ( n 3 ) o(n^3) o(n3),我们思考一下是否可以进行优化。

我们在上面的算法中计算了很多重复的值,我们可以尝试以下排序整个数组,这样我们第一次遍历结束之后,第二次遍历就不需要考虑第一次遍历的数左边的数了,实现了一次剪枝;对于第三次遍历也是一样的,我们不需要考虑第二次遍历的数左边的数。

我们考虑第二,第三次遍历,发现如果此时 nums[i] + nums[j] + nums[k] < 0, 因为 i<j<k,此时我们希望三数之和变大,所以可以右移j,判断是否等于0;同样如果 nums[i] + nums[j] + nums[k] > 0,我们期望他变小一点,则左移 k,检查是否可以等于0。

如果等于零了,说明我们找到了答案,加入最后的结果中即可

注意:关于结果的去重,对于i,left,right,我们都使用while循环排除重复的值,保证结果的唯一性

复杂度

时间复杂度:

遍历了两次数组,所以是: O ( n 2 ) O(n^2) O(n2)

空间复杂度:

添加空间复杂度, 示例: O ( n ) O(n) O(n)

Code

class Solution:def threeSum(self, nums: List[int]) -> List[List[int]]:nums = sorted(nums)n = len(nums)ans = []i = 0 while i < n-2:while i<n and i>0 and nums[i] == nums[i-1]:i+=1if i < n-2 and nums[i+1] + nums[i+2] + nums[i]>0:breakif i < n-2 and nums[i] + nums[-1] + nums[-2] <0:i+=1continueleft,right = i+1,n-1while left<right:if nums[left]+nums[right] + nums[i] < 0:left += 1elif  nums[left]+nums[right] + nums[i] > 0:right -= 1else:ans.append([nums[i],nums[left],nums[right]])left+=1while left<right and nums[left]==nums[left-1]:left+=1right-=1while left<right and nums[right]==nums[right+1]:right-=1i+=1return ans
http://www.qdjiajiao.com/news/8554.html

相关文章:

  • 记事本做网站怎么改字体电脑培训学校课程
  • 外贸网站建设公司搜索指数的数据来源
  • 做自媒体你不得不知道的视频网站seo站长教程
  • 代理注册香港公司关键词seo价格
  • 网站怎么做pc导流页代写文章哪里找写手
  • 哪个公司做网站好苏州ui设计公司
  • 餐饮手机网站建设怎么在广告联盟接广告
  • 建一个公司网站多少钱?影视站seo教程
  • 佛山外贸网站建设咨询爱站网seo综合查询工具
  • 网站备份与恢复外贸营销型网站
  • 寻找昆明网站建设免费网站做seo
  • 商家在网站做淘宝客会给佣金吗北京优化seo公司
  • 微信可以做网站吗seo好学吗入门怎么学
  • 专门做试卷的网站凤凰网全国疫情实时动态
  • 新上市手机百度网站免费优化软件下载
  • Linux做视频网站网速均衡网站推广 方法
  • 免费1级做爰片观看网站在线视频营销比较好的知名公司有哪些
  • 网站主体备案号温州seo结算
  • 建设一个网站需要学习什么bt磁力搜索
  • 怎样做动态网站广州seo外包
  • 天津品牌网站建设公司磁力狗在线引擎
  • php动态网站开发课后习题谷歌paypal官网注册入口
  • 外国网站签到做任务每月挣钱百度网站
  • 中文设计网站seo快速排名外包
  • 雄安做网站的公司用asp做的网站
  • wordpress更换主题方法seoheuni
  • php 网站迁移网站推广优化c重庆
  • 深圳外贸营销型网站建设水平优化
  • 建设学校网站的操作流程具体百度推广登录入口官网
  • r语言做网站苏州seo整站优化