【算法】Leetcode算法题-求两数之和
【摘要】 Leetcode算法题-求两数之和
1.暴力枚举法-梦开始的地方两数之和
//求两数之和
private static int[] twoSum(int[] arr, int target) {
//暴力枚举法
for (int i = 0; i < arr.length; i++) {
for (int j = i+1; j < arr.length; j++) {
if(arr[i]+arr[j] == target){
//返回两个变量的方法
return new int[]{i,j};
}
}
}
return new int[0];
}
2.哈希法求解两数之和
//求两数之和
private static int[] twoSumHash(int[] arr, int target) {
//哈希法
Map<Integer,Integer> map = new HashMap<>();
for (int i = 0; i < arr.length; i++) {
map.put(arr[i],i);
}
//找到下标
for (int i = 0; i < arr.length; i++) {
int key = target - arr[i];
if(map.containsKey(key)){
if (i!=map.get(key)){
return new int[]{i,map.get(key)};
}
}
}
return new int[]{};
}
3.测试
public static void main(String[] args) {
int[] arr = {3,4,7,6,9,1};
//int [] indexArr = twoSumViolence(arr,12);
int [] indexArr = twoSumHash(arr,12);
System.out.println(Arrays.toString(indexArr));
}
【版权声明】本文为华为云社区用户原创内容,转载时必须标注文章的来源(华为云社区)、文章链接、文章作者等基本信息, 否则作者和本社区有权追究责任。如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱:
cloudbbs@huaweicloud.com
- 点赞
- 收藏
- 关注作者
评论(0)