鱼C论坛

 找回密码
 立即注册
查看: 1582|回复: 0

[学习笔记] leetcode 1 Two Sums

[复制链接]
发表于 2019-8-16 03:14:27 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
本帖最后由 Seawolf 于 2019-8-16 03:15 编辑

13.jpg

暴力解法:

  1. class Solution {
  2.     public int[] twoSum(int[] nums, int target) {
  3.         
  4.         int len = nums.length;
  5.         
  6.         int i,j;
  7.         
  8.         int[] array = {-1,-1};
  9.         
  10.         for(i = 0 ; i < len-1; i++){
  11.             
  12.             for(j = i+1; j < len ;j++){
  13.                
  14.                 if(nums[i] + nums[j] == target){
  15.                
  16.                     array[0] = I;

  17.                     array[1] = j;

  18.                     return array;
  19.                 }
  20.             }
  21.         }
  22.         
  23.         return null;
  24.     }
  25. }
复制代码


两个for loop,running time O(n^2)

引入hashmap 对算法进行改进:

  1. class Solution {
  2.    
  3.     public int[] twoSum(int[] nums, int target) {

  4.         Map<Integer, Integer> map = new HashMap<>();
  5.         
  6.         for(int i = 0; i < nums.length; i++) {

  7.             if(map.get(nums[i]) != null) {

  8.                 int res[] = {map.get(nums[i]), I};

  9.                 return res;

  10.             }

  11.             map.put(target - nums[i], i);
  12.         }
  13.         
  14.         return new int[]{};
  15.     }
  16. }
复制代码


running time 提高到 O(n)

本帖被以下淘专辑推荐:

想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2024-4-24 12:31

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表