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

郑州微信网站制作com域名

郑州微信网站制作,com域名,保定做网站,长沙有什么做试卷的网站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/wzjs/321.html

相关文章:

  • 肇庆网站制作朝阳seo排名优化培训
  • 网站策划建设seo和网络推广有什么区别
  • 个人网站怎么做淘宝客如何做百度免费推广
  • wordpress 自定义栏目调用重庆网站seo教程
  • 支持支付宝登录的网站建设第一站长网
  • wordpress搭建web站点标题优化怎样选关键词
  • 美国做色情网站犯法吗网站如何添加友情链接
  • 建设好学校网站企业网站seo平台
  • 网页设计知名网站北京seo包年
  • 什么做电子书下载网站好梅花seo 快速排名软件
  • 如何做网站授权精准广告投放
  • 网站制作商家入驻免费的网页模板网站
  • 网站建设指引精准客源推广引流
  • 怎样做网站管理与维护跨境电商平台
  • 麻城网站制作公司seo深圳培训班
  • 网站值不值得做seoseo查询官网
  • 哪些网站容易做合肥网站关键词优化公司
  • 郑州搭建网站湛江今日头条
  • 承德网站设计公司济南网站设计
  • 怎样把网站做的漂亮长沙新媒体营销
  • 莱芜网站建设资情况介绍搜索引擎技巧
  • 长春城投建设投资有限公司网站如何做好营销
  • web动态网站什么软件可以免费引流
  • wordpress怎么上传自己的网站谷歌广告投放步骤
  • 自己做本市网站深圳推广公司排行榜
  • 网站怎么用栏目做地区词百度号码
  • 官方网站建设建议百度指数指的是什么
  • 建站论坛系统优化科技
  • 网站开发外包维护合同范本北京百度seo工作室
  • 泰安市房产信息网官网seo网络优化专员