leetCode.1:Two Sum

素颜马尾好姑娘i 2022-05-09 04:44 787阅读 0赞

难易程度:★

重要性:★★

70

问题:即给定一个数组nums和一个整数target,如何从数组中找出这两个数?(假定只有一组解)

  1. import java.util.HashMap;
  2. public class Solution {
  3. /*
  4. *分析:遍历数组nums,对于nums[i],我们需要找到target-nums[i]是否在数组中:
  5. * 如果不在,则nums[i]不是我们要找的数;
  6. * 如果在,则我们找到了满足条件的两个数,并且需要返回这两个数在nums数组中的索引值。
  7. * 由于需要返回目标数的索引值,所以我们需要记录nums数组中已经遍历过的数以及该数值在nums数组中的索引位置,
  8. * 所以采用HashMap来保存:key为nums数组中的值,value为对应数在nums数组中的索引下标:
  9. */
  10. public int[] twoSum(int[] nums, int target) {
  11. int[] res = new int[2];
  12. HashMap<Integer, Integer> map = new HashMap<>();
  13. for (int i = 0; i < nums.length; i++) {
  14. if (map.containsKey(target - nums[i])) {
  15. res[0] = map.get(target - nums[i]);
  16. res[1] = i;
  17. } else {
  18. map.put(nums[i], i);
  19. }
  20. }
  21. return res;
  22. }
  23. }

扫描下方二维码,及时获取更多互联网求职面经javapython爬虫大数据等技术,和海量资料分享
公众号菜鸟名企梦后台发送“csdn”即可免费领取【csdn】和【百度文库】下载服务;
公众号菜鸟名企梦后台发送“资料”:即可领取5T精品学习资料java面试考点java面经总结,以及几十个java、大数据项目资料很全,你想找的几乎都有

扫码关注,及时获取更多精彩内容。(博主今日头条大数据工程师)

扫码关注,及时获取更多精彩内容。(博主今日头条大数据工程师)

发表评论

表情:
评论列表 (有 0 条评论,787人围观)

还没有评论,来说两句吧...

相关阅读

    相关 LeetCode1Two Sum

    本类型博客中的各算法的时间复杂度分析均为博主自己推算,本类型博客也是博主自己刷LeetCode的自己的一些总结,因此个中错误可能较多,非常欢迎各位大神在博客下方评论,请不吝赐教