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

大连网站建设新图闻柳州小程序制作公司

大连网站建设新图闻,柳州小程序制作公司,太湖县住房和城乡建设局网站,汕头龙湖网站建设Leetcode1 两数之和 python两种方法实现 文章目录 Leetcode1 两数之和 python两种方法实现方法一:枚举法(暴力解法)方法二:用空间换时间。 给定一个整数数组 nums 和一个整数目标值 target,请你在该数组中找出 和为…

Leetcode1 两数之和 python两种方法实现

文章目录

    • Leetcode1 两数之和 python两种方法实现
      • 方法一:枚举法(暴力解法)
      • 方法二:用空间换时间。

给定一个整数数组 nums 和一个整数目标值 target,请你在该数组中找出 和为目标值 target 的那 两个 整数,并返回它们的 数组下标

你可以假设每种输入只会对应一个答案,并且你不能使用两次相同的元素。

你可以按任意顺序返回答案。

示例 1:

输入:nums = [2,7,11,15], target = 9
输出:[0,1]
解释:因为 nums[0] + nums[1] == 9 ,返回 [0, 1] 。

示例 2:

输入:nums = [3,2,4], target = 6
输出:[1,2]

示例 3:

输入:nums = [3,3], target = 6
输出:[0,1]

提示:

  • 2 <= nums.length <= 10^4
  • -10^9 <= nums[i] <= 10^9
  • -10^9 <= target <= 10^9
  • 只会存在一个有效答案

分析:给定一个目标数值,需要返回和为目标数值的两个数的下标,而且答案只有一个。即对于a+b = target, 有且只有一个解。

方法一:枚举法(暴力解法)

对于一个数组[c1,c2,c3,c4,c5], 可以一组一组的判断,即(c1,c2),(c1,c3),(c1,c4),(c1,c5),

(c2,c3),(c2,c4),(c2,c5)

(c3,c4),(c3,c5),

(c4,c5)

即枚举法。

class Solution(object):def twoSum(self, nums, target):""":type nums: List[int]:type target: int:rtype: List[int]"""n = len(nums) # 获取数组的长度for i in range(n):for j in range(i+1,n):if(nums[i]+nums[j] == target):return [i,j]return []

时间复杂度O(n^2), 空间复杂度O(1), 因为只使用了3个临时变量,n, i,j.

分析:时间复杂度很高,空间复杂度很低。如何能够降低时间复杂度,一种思路是用空间换时间

方法二:用空间换时间。

我们还是来看枚举法:

(c1,c2),(c1,c3),(c1,c4),(c1,c5),

(c2,c3),(c2,c4),(c2,c5)

(c3,c4),(c3,c5),

(c4,c5)

大部分时间花在了寻找第二个数上。有一个基本的观察是:如果第二个数与第一个数的和为目标数值,那么目标数值减去第二个数一定存在于数组中。

快速查找数值的结构是哈希集合或者哈希表,python中对应的结构是dict.

第一遍遍历的时候,如果当前数为答案中的第二个数,则target-当前数 则一定位于当前数之前的数组成的哈希集合中。
使用一个叫做dict的数据结构,键为数,值为当前数的索引。

class Solution(object):def twoSum(self, nums, target):""":type nums: List[int]:type target: int:rtype: List[int]"""hashtable = dict()for i, num in enumerate(nums):if(target - num in hashtable):return [i, hashtable[target-num]]hashtable[num]= i

时间复杂度 O(n), 空间复杂度O(n)

结果:

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

链接:

https://leetcode.cn/problem-list/array/

从这一期leetcode开始,我会经常回来看我的博客,如果博主们觉得哪里看不懂,欢迎随时在评论区提出。

刷Leetcode就如同刷象棋路边摊一样,最开始刷的时候,觉得某一个象棋的路数好奇妙,刷着刷着回过头来看时发现那个招数在自己的眼中变得没那么令人惊讶了,变得稀松平常了。

http://www.dtcms.com/a/460529.html

相关文章:

  • 平台类网站有哪些网站更换空间改版收录
  • 专业外贸网站制作攀枝花仁和住房和城乡建设局网站
  • 有教做点心的网站吗wordpress 摘要不显示
  • 学网站建设要多久网站建设中 模板素材
  • 做网站 十万小程序后端怎么搭建
  • 寒亭营销型网站建设wordpress 进销存
  • 做杂志模板下载网站ppp模式在网站建设的
  • 知识产权教育平台网站开发总结网站开发模板教务管理
  • 天律网站建设上班没事做看什么网站
  • 网站开发 搜索wordpress建站阿里云
  • 平面设计专用网站建一个pc网站需要多少钱
  • 网站怎样建立数据库连接网络营销理论与实务
  • 网站建设报价方案.xlswordpress single页面
  • 网站建设细化流程咸宁商城网站建设
  • 网站建设岗位招聘犀牛建设网站
  • 网站出现的的问题视觉中国网站
  • 一个网站做两个优化可以做吗做企业网站后期还需要费用吗
  • 网站服务器是干什么的专业网站建站公司
  • 网站架构演变流程苏州前几天网站建设
  • 蓝色系网站竞价排名点击
  • 怎么给网站做百度坐标定位做网站需注重的几点
  • 开题报告风景区网站开发北京网站维护浩森宇特
  • 网站建设业务好跑吗wordpress工作室
  • 无锡网站 制作中山手机网站建设哪家好
  • 网站建设核电网络项目
  • 网站后期维护方案漯河网站建设漯河
  • 网页和网站的不同苏州公司名称查询
  • a站是指哪个网站学校门户网站建设说明
  • 广州网站建设商家理卖做各视频网站的会员
  • 汕头建设企业网站广元做开锁网站