LeetCode 1. 两数之和

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

你可以假设每种输入只会对应一个答案。但是,数组中同一个元素在答案里不能重复出现。

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

来源:力扣(LeetCode)
链接:https://leetcode.cn/problems/two-sum
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。


开始想法(方法一:暴力枚举)

直接n^2暴力查找一遍,枚举x,遍历数组找target-x找到就标记输出。

代码
class Solution {
public:vector<int> twoSum(vector<int>& nums, int target) {int len=nums.size();vector<int> a;int flg=0;for(int i=0;i<len-1;i++){for(int j=i+1;j<len;j++){if(nums[i]+nums[j]==target){a.push_back(i);a.push_back(j);flg=1;break;}}if(flg==1) break;}return a;}
};

看题解之后(方法二:哈希)

注意到方法一中,时间复杂度较高的原因主要是枚举的过程中需要逐一判断两数之和是不是target,因此我们需要一种更为优秀的算法来快速寻找出对应的两个数。如果存在,我们将找出它的索引。

哈希表恰好可以满足我们的需求,可以将寻找target-x的时间复杂度从*O(n)降低为O(1)*。

我们只需要创建一个哈希表,对于每一个x,我们查询哈希表中是否存在target-x,然后将x插入到哈希表中,就可以保证让x不和自己匹配。

代码
class Solution {
public:vector<int> twoSum(vector<int>& nums, int target) {unordered_map <int,int> hashtable;int len=nums.size();for(int i=0;i<len;i++){auto it=hashtable.find(target-nums[i]);if(it!=hashtable.end()){return{it->second,i};}hashtable.insert(make_pair(nums[i],i));}return {};}
};

收获

  • 从这道题开始一个新的阶段吧,不管是以前会的还是不会的,忘掉的还是不熟悉的,通过刷题,都要拾起来,得考虑考虑以后了。
  • 这道题里面,算是拾起来了很多stl 的知识,vectormap以及内部函数的操作。
    - vector里面的 size,push_back
    - unordered_map里面的 find,end 等等
  • 第二种解法中要注意在查找之后再更新哈希表中这一项的信息,以避免自己和自己匹配这种情况的发生

LeetCode 1. 两数之和相关推荐

  1. [leetcode]1.两数之和

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

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

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

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

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

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

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

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

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

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

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

  7. LeetCode 01两数之和02两数相加

    力扣 LeetCode01两数之和 LeetCode02两数之加 前言:第一次LeetCode打卡题解,前面组织的打卡活动从今天开始正式开始了,很多csdn和公众号小伙伴以及加入了,欢迎加入!详细看力 ...

  8. Leetcode 1. 两数之和 (Python版)

    有粉丝说我一个学算法的不去做Leetcode是不是浪费,于是今天闲来没事想尝试一下Leetcode,结果果断翻车,第一题没看懂,一直当我看到所有答案的开头都一样的时候,我意识到了我是个铁憨憨,人家是让 ...

  9. 【LeetCode】两数之和

    package leetcode.editor.cn;//给定一个整数数组 nums 和一个目标值 target,请你在该数组中找出和为目标值的那 两个 整数,并返回他们的数组下标. // // 你可 ...

最新文章

  1. 深入理解HTTP Session
  2. ToDesk远程控制软件
  3. Python 数据处理函数 round()、int()、floor()、ceil()的用法
  4. EasyExcel 2 上传 下载
  5. Oracle数据库中number类型在hibernate的引用
  6. Entity Framework 4 in Action读书笔记——第四章:使用LINQ to Entities查询:执行手动查询...
  7. C语言之变量存储类型与链接属性
  8. 浅谈ARMv7-A协处理器CP15
  9. UI实用素材|优秀的仪表盘对每项业务都很重要
  10. ​php mysql教学管理系统计算机毕业设让网站作品
  11. 大数据时代已经来临,正在改变我们的生活
  12. tensor数据类型,数据转换和新建数据操作
  13. 【第9篇】Python爬虫实战-银行卡归属地查询
  14. 关于货币流动的一点思考
  15. 模型思维-THE MODEL THINKER
  16. 墙裂推荐!2019 年度数据库领域热点汇总
  17. 数学之英文写作——基本中英文词汇(一般术语、算术与代数的常用词汇)
  18. excel oledb mysql_excel连接数据库oledb
  19. 三菱机械臂demo程序
  20. live555 android,Android RTSP/UDP“RTSP/1.0 461 Unsupported transport”通过蜂窝网络(4G)

热门文章

  1. Android平台OpenGL实现全景图片视频播放
  2. linux中使用ps提示 bash: ps: command not found
  3. java遍历map values_java遍历Map的四种方式
  4. 微型计算机原理尹建华答案,《微型计算机原理和接口技术》(尹建华)习题答案解析...
  5. cibc app for android,cibc mobile banking app
  6. shell脚本中如何获取命令的参数(2) ----处理命令参数
  7. C++智能指针shared_ptr用法
  8. QQ会员信息免密查询API接口
  9. Office2021版64位+mathtype6.9
  10. 全地形比赛小车制作分享