面试必考真题-算法篇 牛客网
数组 哈希
题目描述
给出一个整数数组,请在数组中找出两个加起来等于目标值的数,
你给出的函数twoSum 需要返回这两个数字的下标(index1,index2),需要满足 index1 小于index2.。注意:下标是从1开始的
假设给出的数组中只存在唯一解
例如:
给出的数组为 {20, 70, 110, 150},目标值为90
输出 index1=1, index2=2
题目分析
利用HashMap进行存储,每次存储利用target-当前数字的值作为key,将当前数字的坐标作为value。同时,每次存储前进行判断,如果map中的key包含当前数字,则证明存在两个数等于target值,则可以找到这两个数字的坐标。
下面是Java代码
import java.util.*;
public class Solution {
/**
*
* @param numbers int整型一维数组
* @param target int整型
* @return int整型一维数组
*/
public int[] twoSum (int[] numbers, int target) {
// write code here
int len = numbers.length;
int[] result = new int[2];
//map里面放 键为target-每个数的结果 值为下标
//每次放入的时候看是否包含 当前值
//有的话说明当前值和已包含的值下标的那个元素为需要的结果
HashMap<Integer, Integer> map = new HashMap<>();
for(int i = 0 ; i < len ; i++){
if(map.containsKey(numbers[i])){
result[0] = map.get(numbers[i])+1;
result[1] = i+1;
break;
}else{
map.put(target-numbers[i],i);
}
}
return result;
}
}