两数之和
给定一个整数数组 nums 和一个目标值 target,请你在该数组中找出和为目标值的那 两个 整数,并返回他们的数组下标。
你可以假设每种输入只会对应一个答案。但是,数组中同一个元素不能使用两遍。
此题一共想到两种解法,
- 暴力法
class Solution {
public int[] twoSum(int[] nums, int target) {
for(int i=0;i<nums.length-1;i++){
for(int j=i+1;j<nums.length;j++){
if(nums[i]+nums[j]==target){
int s[] = {i,j};
return s;
}
}
}
return null;
}
}
2.通过map集合的方法直接检索出 ,
class Solution {
public int[] twoSum(int[] nums, int target) {
Map<Integer,Integer> map = new HashMap();//用来存储遍历过得数据
for(int i=0;i<nums.length;i++){
int temp = target-nums[i];//用来和遍历过得数据比较
if(map.containsKey(temp)){
return new int[]{map.get(temp),i};
}
map.put(nums[i],i);
}
return null;
}
}
本文介绍了解决'两数之和'问题的两种方法:一种是暴力法,通过双重循环找到和为目标值的两个数;另一种是利用哈希表,提高查找效率。每种方法都附带了详细的代码实现。

963

被折叠的 条评论
为什么被折叠?



