博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
[leetcode]3Sum @ Python
阅读量:6644 次
发布时间:2019-06-25

本文共 1376 字,大约阅读时间需要 4 分钟。

原题地址:http://oj.leetcode.com/problems/3sum/

题意:从一个数组中找到三个数,使这三个数的和为0。有可能存在多组解,也有可能存在重复的解,所以需要去重。比如:num=[-1,0,1,2,-1,-4];那么存在两组解:[[-1,0,1],[-1,-1,2]],解中的数需要是从小到大排序状态。

解题思路:1,先将数组排序。

     2,排序后,可以按照TwoSum的思路来解题。怎么解呢?可以将num[i]的相反数即-num[i]作为target,然后从i+1到len(num)-1的数组元素中寻找两个数使它们的和为-num[i]就可以了。下标i的范围是从0到len(num)-3。

     3,这个过程要注意去重。

       4,时间复杂度为O(N^2)。

代码:

class Solution:    # @return a list of lists of length 3, [[val1,val2,val3]]    def threeSum(self, num):        num.sort()        res = []        for i in range(len(num)-2):            if i == 0 or num[i] > num[i-1]:                left = i + 1; right = len(num) - 1                while left < right:                    if num[left] + num[right] == -num[i]:                        res.append([num[i], num[left], num[right]])                        left += 1; right -= 1                        while left < right and num[left] == num[left-1]: left +=1                        while left < right and num[right] == num[right+1]: right -= 1                    elif num[left] + num[right] < -num[i]:                        while left < right:                            left += 1                            if num[left] > num[left-1]: break                    else:                        while left < right:                            right -= 1                            if num[right] < num[right+1]: break        return res

 

转载地址:http://ftevo.baihongyu.com/

你可能感兴趣的文章
'utf-8' codec can't decode byte 0xd0 in position 0问题
查看>>
【评分】第四次作业--项目选题报告(团队)
查看>>
C Primer Plus 第3章 数据和C 编程练习
查看>>
不容易系列之一 (错排公式)
查看>>
JDK API
查看>>
vs2005“工具”下添加”ESRI GuidGen“
查看>>
SEO心得分享
查看>>
linux shell 数组建立及使用技巧
查看>>
百度地图自己添加 标识地点 代码
查看>>
编译器:gcc, clang, llvm
查看>>
CentOS / RHEL 7 : Chrony V/s NTP (Differences Between ntpd and chronyd)
查看>>
【为了爱,为了pascal】目录NO.1(引子至..)
查看>>
luoguP4234 最小差值生成树
查看>>
关于人每天所需热量:2017-3-13
查看>>
php笔记篇(二)
查看>>
单元测试和记录日志
查看>>
软件安装方式
查看>>
网络爬虫系统Heritrix的结构分析 (个人读书报告)
查看>>
eclipse 分屏显示同一文件
查看>>
Canvas 与 SVG 的比较
查看>>