1.两数之和(题号:1)

import java.util.HashMap;

public class TwoSum {

    //测试
    public static void main(String[] args) {
        int[] nums = {2,7,9,11};
        int target = 9;
        TwoSum twoSum = new TwoSum();
        int[] ints = twoSum.twoSum3(nums, target);
        for (int i = 0; i <ints.length ; i++) {
            System.out.println(ints[i]);
        }
    }

    /**
     * 方法一:暴力破解 时间复杂度O(n^2) 空间复杂度O(1)
     * @param nums
     * @param target
     * @return
     */
    public int[] twoSum(int[] nums, int target) {
        int n = nums.length;
        for (int i = 0; i < n-1; i++) {
            for (int j = i+1; j < n; j++) {
                if(nums[i]+nums[j]==target){
                    return new int[]{i,j};
                }
            }
        }
        //如果找不到 抛出异常
        throw new IllegalArgumentException("no solution");
    }

    /**
     * 方法二:哈希表保存所有数的信息 时间复杂度O(n) 空间复杂度O(n)
     * @param nums
     * @param target
     * @return
     */
    public int[] twoSum2(int[] nums, int target) {
        int n = nums.length;
        //定义一个哈希表
        HashMap<Integer,Integer> map = new HashMap<>();
        //1.遍历数组,把所有数据保存到hash表
        for (int i = 0; i < n; i++) {
            map.put(nums[i],i);
        }
        //2.再次遍历数组,寻找每个数对应的哪个数是否存在
        for (int i = 0; i < n; i++) {
            int thatNum = target-nums[i];
            //如果哪个数存在,并且不是当前数自身,就直接返回结果
            if(map.containsKey(thatNum)&&map.get(thatNum)!=i){
                return new int[]{i,map.get(thatNum)};
            }
        }
        //如果找不到 抛出异常
        throw new IllegalArgumentException("no solution");
    }

    /**
     * 方法三:遍历一次哈希表 时间复杂度O(n) 空间复杂度O(n)
     * @param nums
     * @param target
     * @return
     */
    public int[] twoSum3(int[] nums, int target) {
        int n = nums.length;
        //定义一个哈希表
        HashMap<Integer,Integer> map = new HashMap<>();
        //遍历数组,寻找每个数对应的哪个数是否存在
        for (int i = 0; i < n; i++) {
            int thatNum = target-nums[i];
            //如果哪个数存在,并且不是当前数自身,就直接返回结果
            if(map.containsKey(thatNum)&&map.get(thatNum)!=i){
                return new int[]{map.get(thatNum),i};
            }
            map.put(nums[i],i);
        }
        //如果找不到 抛出异常
        throw new IllegalArgumentException("no solution");
    }
}
全部评论

相关推荐

08-21 10:10
复旦大学 运营
秋招第一个简历挂我的,有点不知好歹了
强大的社畜在走神:复旦✌️也挂吗,阿里云你想干嘛😡
投递阿里云等公司10个岗位
点赞 评论 收藏
分享
看到这个面评结果有点绷不住了
嗨害嗨我来了:他们这是招迪迦吗,还光,直接双手呈 90 度让他们见识见识什么叫做光
点赞 评论 收藏
分享
昨天 15:18
广东科技学院 C++
点赞 评论 收藏
分享
勇敢的90后想交流:我愿意付费上班,楼主你就安心字节待着吧,我是真的喜欢上班
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务