LeetCode题解 #1 Two Sum
在LeetCode做的第一到题
题目大意:给出n个数,在其中找出和为一个特定数的两个数。
Input: numbers={2, 7, 11, 15}, target=9
Output: index1=1, index2=2
返回这两个数在原数组内的下标。
我的思路:
1、遍历数组 int temp = target-num[i]
2、查找数组内有没有符合的temp存在。
3、因为这个题目是肯定会有符合条件的两个数的,所以temp肯定存在。
但这样会遇到这些问题:
1、查找最快的是使用二分查找,但是二分查找需要数组有序!
2、给数组排序的话,最快是使用快速排序!
3、但是后来发现,快速排序之后,元素的下标基本改变了,但是题目要求返回原数组中的下标!
4、如果有相同的两个数符合条件的话,返回靠后的那个数,即二分查找要返回最后一个找到的数!
综合以上,就需要使用大量的代码进行修补。
我的解决办法是:
设计一个类
class fuzhu{
public int data;//存放数据
public int ori;//存放原来数组的下标
}
遍历原数组,建立这个fuzhu数组
这样就不会在快排的时候丢失原来的下标。
至于二分查找,因为都是有序的,所以相同的数据都会排在一起,所以在找到一个数只有,只要一直往后遍历看看有没有相同的数就好。
以上是刚开始做的思路,但这种做法真的太麻烦了,懒得贴代码了!
正确做法:HashMap!
1、遍历一次数组,建立一个Map。Map里面 key是元素的值,value是元素原来的下标。
2.不需要排序,不需要二分查找,直接看Map里面有没有temp的key存在(除了自己),返回key的value。
3、由于相同的key会覆盖掉原来的value值,所以Map里面的value值肯定是靠后的那一个!
public static int[] twoSum(int[] nums, int target){
Map<Integer,Integer> hash = new HashMap<Integer,Integer>();
int [] ans = new int [2];
for(int i=0;i<nums.length;i++){
hash.put(nums[i], i);
}
//System.out.println(hash.get(100));
for(int i=0;i<nums.length;i++){
int temp = target - nums[i];
//System.out.println(temp);
if(hash.get(temp)!=null&&hash.get(temp)!=i){
//System.out.println(hash.get(temp));
if(i<=hash.get(temp)){
ans[0]=i+1;
ans[1]=hash.get(temp)+1;
break;
}
else{
ans[0]=hash.get(temp)+1;
ans[1]=i+1;
break;
}
}
}
return ans;
}
总结:这道题如果只是查找有没有这两个数存在的话,用我的第一次的方法是很好的。但是要留意题目说的,返回原来数组中的值,并且要最靠后,用Hash表的话
由于相同的key会覆盖掉原来的value值,所以Map里面的value值肯定是靠后的那一个!所以HashMap真是最好的办法啦。
跟数组有关的题目,很大部分用HashMap可以很快解决。
LeetCode题解 #1 Two Sum的更多相关文章
- [LeetCode 题解]:Path Sum
前言 [LeetCode 题解]系列传送门: http://www.cnblogs.com/double-win/category/573499.html 1.题目描述 Given a bi ...
- LeetCode题解39.Combination Sum
39. Combination Sum Given a set of candidate numbers (C) (without duplicates) and a target number (T ...
- 《LeetBook》LeetCode题解(1) : Two Sum[E]——哈希Map的应用
001.Two Sum[E] Two SumE 题目 思路 1双重循环 2 排序 3 Hashmap 1.题目 Given an array of integers, return indices o ...
- LeetCode 题解之 Two Sum
1.题目描述 2.问题分析 使用hashTable 寻找,target - num[i] ,将时间复杂度降低到 O(n): 3.代码 vector<int> twoSum(vector ...
- LeetCode题解之 two sum 问题
1.题目描述 2.题目分析 考虑使用hashMap的方式将数组中的每个元素和下表对应存储起来,然后遍历数组,计算target 和 数组中每个元素的差值,在hashMap中寻找,一直到找到最后一对. 3 ...
- [LeetCode 题解] Combination Sum
前言 [LeetCode 题解]系列传送门: http://www.cnblogs.com/double-win/category/573499.html 1.题目描述 Given a se ...
- [LeetCode 题解]: Two Sum
前言 [LeetCode 题解]系列传送门: http://www.cnblogs.com/double-win/category/573499.html 1.题目描述 Given an a ...
- 【LeetCode题解】二叉树的遍历
我准备开始一个新系列[LeetCode题解],用来记录刷LeetCode题,顺便复习一下数据结构与算法. 1. 二叉树 二叉树(binary tree)是一种极为普遍的数据结构,树的每一个节点最多只有 ...
- 【LeetCode题解】136_只出现一次的数字
目录 [LeetCode题解]136_只出现一次的数字 描述 方法一:列表操作 思路 Java 实现 Python 实现 方法二:哈希表 思路 Java 实现 Python 实现 方法三:数学运算 思 ...
随机推荐
- 密钥库文件格式[keystore]代码
密钥库文件格式[keystore]代码 格式 : JKS 扩展名 : .jks/.ks 描述 : [Java Keystore]密钥库的Java实现版本,pro ...
- 去除inline-block元素间间距的N种方法(转)
一.现象描述 真正意义上的inline-block水平呈现的元素间,换行显示或空格分隔的情况下会有间距,很简单的个例子: <input /> <input type="su ...
- Cocos2d-X 3.2环境的配置
大三寒假时间特别长,终于准备坐下来好好去学一直想涉足的游戏开发.既然准备学,就要找个出色的.跨平台的引擎来实现自己的计划.最终我选定了Cocos2d-X. 在折腾了很久之后,我终于把Cocos2d-X ...
- threejs 画二维圆(圆弧)
画圆: var radius = 40, segments = 64, material = new THREE.LineBasicMaterial({ color: 0x0000ff }), geo ...
- 每天一个linux命令(性能、优化):【转载】top命令
top命令是Linux下常用的性能分析工具,能够实时显示系统中各个进程的资源占用状况,类似于Windows的任务管理器.下面详细介绍它的使用方法.top是一个动态显示过程,即可以通过用户按键来不断刷新 ...
- Java调用函数传递参数到底是值传递还是引用传递
今天翻看微信上有关Java技术的公众号时,看到了一篇关于Java中值传递的问题,文章讨论了在Java中调用函数进行传参的时候到底是值传递还是引用传递这个面试时会问到的问题.之前也接触过类似的问题,但只 ...
- Tomcat 运行 idea 编译好的 .class JavaWeb 项目
对于新手来说,对于项目部署,有时候就是以为拷贝在idea控制台里面跑的项目放到tomcat里面的webapps里面跑就可以了,这仅仅限于静态项目..... 他不像PHP , 修改源码直接可以跑, 而J ...
- xpath与css_selector定位详解
例题:分别用xPath和css_selector定位下图的img标签 答案: xpath:.//*[@id='fstscr']/div[3]/div[2]/a/img css_selector: . ...
- vi/vim显示中文字符并且去掉^M的方法
vim上经常会碰到中文显示不正常的现象,也就是传说中的乱码.搜索了一下,在 http://www.chinalinuxpub.com/bbs/showthread.php?t=45475 找到了一个解 ...
- Tomcat(64位)免安装版的环境安装与配置
本篇博客主要介绍Tomcat(64位)免安装版的环境安装与配置,该篇文章同样适合于32位Tomcat免安装版的环境安装与配置. 该篇博客中的大部分内容同百度经验中的<出现unable to op ...