关注微信公众号:CodingTechWork,一起学习进步。

题目

Two Sum
Given an array of integers, return indices of the two numbers such that they add up to a specific target.

You may assume that each input would have exactly one solution, and you may not use the same element twice.

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

你可以假设每种输入只会对应一个答案。但是,数组中同一个元素不能使用两遍。

Example:Given nums = [2, 7, 11, 15], target = 9,Because nums[0] + nums[1] = 2 + 7 = 9,
return [0, 1].

解题

1 暴力解题

class Solution {public int[] twoSum(int[] nums, int target) {//遍历每个元素nums[i],查找是否存在值nums[j]相加后等于target。for (int i = 0; i < nums.length; i++){for(int j = i+1; j < nums.length;j++) {if (nums[i] + nums[j] == target) {return new int[]{i, j};}}}return null;  }
}

这种暴力解题,两层循环,每个元素遍历一遍,内部嵌套再把剩余的每个元素遍历一遍求和寻找目标合适元素,时间复杂度为o(n^2),空间复杂度为o(1)

2 2次遍历解题

class Solution {public int[] twoSum(int[] nums, int target) {Map<Integer, Integer> map = new HashMap();//存储到HashMap中for (int i = 0; i < nums.length; i++){map.put(nums[i], i);}//遍历数组for (int i = 0; i < nums.length; i++) {//算差值int result = target - nums[i];//在map中查找索引不是本身i的的差值即为结果值if(map.containsKey(result) && map.get(result) != i) {return new int[] {i,map.get(result)};}}throw new IllegalArgumentException("No two sum solution");}
}

这种两遍哈希表的方式,哈希表存储n个元素,增加了空间复杂度,第一次是遍历数组插入到哈希表中,时间复杂度为o(n),但是第二次查询时间由原来遍历数组的o(n)减少到o(1)。所以总体时间复杂度为o(n),空间复杂度为o(n)

3 一次遍历解题

class Solution {public int[] twoSum(int[] nums, int target) {Map<Integer, Integer> map = new HashMap<>();for (int i = 0; i < nums.length; i++) {//计算结果int result = target - nums[i];//map中是否包含这个结果,若包含则返回该结果,及对应的目前数组的indexif (map.containsKey(result)) {//map是后添加元素的,所以map索引在前,i在后return new int[]{map.get(result), i};}map.put(nums[i], i);}throw new IllegalArgumentException("no two sum solution");}
}

这种方式也是参考了题解中的第一个官方的,自己想不到;他是采用了一次遍历的同时,最后将前面遍历的值放入到map中,然后后续的遍历过程中,不断的把map的值(也就是数组中已遍历的前方值)和当前后方值做比较。所以返回的时候,map的索引在前,i在后。

参考 two sum

leetcode算法—两数之和 Two Sum相关推荐

  1. LeetCode 1. 两数之和 Two Sum

    给定一个整数数组和一个目标值,找出数组中和为目标值的两个数. 你可以假设每个输入只对应一种答案,且同样的元素不能被重复利用. 示例: 给定 nums = [2, 7, 11, 15], target ...

  2. [leetcode]1.两数之和

    [leetcode]1.两数之和 题目 给定一个整数数组 nums 和一个整数目标值 target,请你在该数组中找出 和为目标值 的那 两个 整数,并返回它们的数组下标. 你可以假设每种输入只会对应 ...

  3. C/C++描述 LeetCode 167. 两数之和 II - 输入有序数组

    C/C++描述 LeetCode 167. 两数之和 II - 输入有序数组   大家好,我叫亓官劼(qí guān jié ),在CSDN中记录学习的点滴历程,时光荏苒,未来可期,加油~博主目前仅在 ...

  4. LeetCode 1. 两数之和

    LeetCode 1. 两数之和 给定一个整数数组 nums 和一个整数目标值 target,请你在该数组中找出 和为目标值 target 的那 两个 整数,并返回它们的数组下标. 你可以假设每种输入 ...

  5. 领扣-1/167 两数之和 Two Sum MD

    Markdown版本笔记 我的GitHub首页 我的博客 我的微信 我的邮箱 MyAndroidBlogs baiqiantao baiqiantao bqt20094 baiqiantao@sina ...

  6. [hashmap|空间换时间] leetcode 1 两数之和

    [hashmap|空间换时间] leetcode 1 两数之和 1.题目 题目链接 给定一个整数数组 nums 和一个目标值 target,请你在该数组中找出和为目标值的那两个整数,并返回他们的数组下 ...

  7. 【前端来刷LeetCode】两数之和与两数相加

    大部分玩前端的小伙伴,在算法上都相对要薄弱些,毕竟调样式.调兼容就够掉头发的了,哪还有多余的头发再去折腾. 确实在前端中需要使用到算法的地方是比较少,但若要往高级方向发展,算法的基本功就非常重要啦.对 ...

  8. leetCode:twoSum 两数之和 【JAVA实现】

    LeetCode 两数之和 给定一个整数数组,返回两个数字的索引,使它们相加到特定目标. 您可以假设每个输入只有一个解决方案,并且您可能不会两次使用相同的元素. 更多文章查看个人博客 个人博客地址:t ...

  9. 力扣(leetcode)-1. 两数之和

    描述 给定一个整数数组 nums 和一个整数目标值 target,请你在该数组中找出 和为目标值 target 的那 两个 整数,并返回它们的数组下标. 你可以假设每种输入只会对应一个答案.但是,数组 ...

最新文章

  1. ViewPager (下)-- 利用 Fragment 实现美丽的 页面切换
  2. boost::fusion::any用法的测试程序
  3. CodeForces 558A,B
  4. linux红帽6架设apache,linux Redhat6.5 中 编译安装apache
  5. 4K屏幕+5500万像素摄像头,以成未来手机的一大趋势
  6. XML安全之Web Services
  7. cad结构字体_AutoCAD字体选择:如何快速选中gbcbig.shx通用字体
  8. c语言链栈案例,C语言链栈
  9. 在线制作安卓手机主题
  10. 2022年兽药行业发展前景
  11. pkg-config 详解
  12. 吴恩达《机器学习》第四章:多元线性回归
  13. 更换新电脑,如何将旧电脑数据/文件传输到新电脑?
  14. kermit的安装、配置、使用 .
  15. 你必须知道的 10 个元宇宙最佳案例
  16. 装饰模式--小美的生日蛋糕
  17. 在宜宾,看见未来中国的产融平台样本
  18. ted学习方法_视世界为1000人,我是如何学习内容策略的TED设计系统的
  19. [转]从0到1亿美元 ---- PopCap创始人John Vechey自述
  20. 目标检测:Imbalance Problems in Object Detection: A Review

热门文章

  1. python基础之os.system函数执行命令行语句
  2. CentOS修改yum源【噗哈哈】
  3. OpenCV中基本数据结构(2)_Scalar
  4. linux版本和目录结构
  5. lnmp修改mysql上传大小限制_安装Linux+Nginx+MySQL+PHP(LNMP)集成环境,解除上传文件大小限制...
  6. js时间搓化为今天明天_来揭秘化妆品为啥会搓泥?
  7. DreamweaverCS6搭建配置php本地站点(图文教程)- 教程篇
  8. Vue.js项目去除url中的#/ - 解决篇
  9. 电脑格式化后需要重装系统吗_重装系统后c盘文件丢失,电脑重装系统后c盘文件能恢复吗...
  10. 精仿腾讯视频php源码开源免安装版,自动采集