leetcode两数之和

题目描述

题目.png

解题思路

借助哈希表,将数组元素的值和索引传入map的同时,计算target-nums[i],判断结果是否在map中,如果在则返回两个元素的索引。

java实现

class Solution{
  public int[] twoSum(int[] nums,int target){
    Map<Integer,Integer> map=new HashMap<>();
    for(int i=0;i<nums.length;i++){
      int res=target-nums[i];
      if(map.containsKey(res)){
        return int[]{i,map.get(nums[i])};
      }
      else{
        map.put(nums[i],i);
      }
    }
    throw new IllegalArgumentException("no two sum solution");
  }
}
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容