Java实现LeetCode(1.两数之和)

Java实现LeetCode(1.两数之和)

一、题目描述

给定一个整数数组和一个目标值,找出数组中和为目标值的两个数。

你可以假设每个输入只对应一种答案,并且同样的元素不能被重复利用。

示例:

给定 nums = [2, 7, 11, 15], target = 9

因为 nums[0] + nums[1] = 2 + 7 = 9
所以返回 [0, 1]

二、思路分析

1.暴力法

最容易想到的思路是循环每个数,并查找是否存在与其配对的目标元素。我们可以通过嵌套循环的方式来简单实现:

public static int[] twoSum(int[] nums, int target) {
    for (int i = 0; i < nums.length; i++) {
        for (int j = i + 1; j < nums.length; j++) {
            if (nums[j] == target - nums[i]) {
                return new int[] { i, j };
            }
        }
    }
    throw new IllegalArgumentException("No two sum solution");
}

复杂度分析:

  • 时间复杂度:O(N^2)
  • 空间复杂度:O(1)

2.哈希表法

通过使用哈希表,我们可以将寻找目标元素的时间从 O(N) 降低到 O(1)。使用哈希表的时候,需要遍历一次数组并将每个元素及其下标添加到哈希表中,然后遍历一次数组并查找其目标元素是否存在于哈希表中。

public static int[] twoSum(int[] nums, int target) {
    Map<Integer, Integer> map = new HashMap<>();
    for (int i = 0; i < nums.length; i++) {
        map.put(nums[i], i);
    }
    for (int i = 0; i < nums.length; i++) {
        int complement = target - nums[i];
        if (map.containsKey(complement) && map.get(complement) != i) {
            return new int[] { i, map.get(complement) };
        }
    }
    throw new IllegalArgumentException("No two sum solution");
}

复杂度分析:

  • 时间复杂度:O(N)
  • 空间复杂度:O(N)

三、完整代码

import java.util.HashMap;
import java.util.Map;

public class Solution {
    public static int[] twoSum(int[] nums, int target) {
        Map<Integer, Integer> map = new HashMap<>();
        for (int i = 0; i < nums.length; i++) {
            map.put(nums[i], i);
        }
        for (int i = 0; i < nums.length; i++) {
            int complement = target - nums[i];
            if (map.containsKey(complement) && map.get(complement) != i) {
                return new int[] { i, map.get(complement) };
            }
        }
        throw new IllegalArgumentException("No two sum solution");
    }

    public static void main(String[] args) {
        int[] nums = {2, 7, 11, 15};
        int target = 9;
        int[] result = twoSum(nums, target);
        System.out.println(result[0] + " " + result[1]);
        // 输出:0 1
    }
}

四、两条示例说明

1.输入数组无解

若给定数组为 [1, 2, 3, 4],目标元素为 9,无解。

public static void main(String[] args) {
    int[] nums = {1, 2, 3, 4};
    int target = 9;
    try {
        int[] result = twoSum(nums, target);
        System.out.println(result[0] + " " + result[1]);
    } catch (Exception e) {
        System.out.println(e.getMessage());
        // 输出:No two sum solution
    }
}

2.数组中存在相同元素

若给定数组为 [2, 2, 3, 4], 目标元素为 4,返回 [0, 1]

public static void main(String[] args) {
    int[] nums = {2, 2, 3, 4};
    int target = 4;
    int[] result = twoSum(nums, target);
    System.out.println(result[0] + " " + result[1]);
    // 输出:0 1
}

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:Java实现LeetCode(1.两数之和) - Python技术站

(0)
上一篇 2023年5月19日
下一篇 2023年5月19日

相关文章

  • jsp+Servlet编程实现验证码的方法

    下面我来详细讲解“jsp+Servlet编程实现验证码的方法”的完整攻略。 什么是验证码? 验证码(CAPTCHA)是指计算机应用程序为区分用户是真实用户还是计算机程序而推出的一种测试。常见的验证码类型包括数字、字母、滑块等形式,用户需要正确地填写系统生成的图形码信息才能进行下一步操作。 实现验证码的原理 验证码的实现原理是利用了Web开发中的Session…

    Java 2023年6月15日
    00
  • SpringBoot集成JPA的示例代码

    下面我会详细讲解“SpringBoot集成JPA的示例代码”的完整攻略,过程中会包含两条示例。 1. 环境准备 在开始之前,我们需要确保我们的开发环境中已经安装好了以下软件: JDK 8或以上版本 IntelliJ IDEA或其他一款IDE 然后,我们需要确保我们在项目中引入了以下依赖: <dependency> <groupId>o…

    Java 2023年5月20日
    00
  • Spring Boot自定义 Starter并推送到远端公服的详细代码

    以下是详细讲解 Spring Boot 自定义 Starter 并推送到远端公服的详细攻略,过程中包含两个示例。 1. 确定自定义 Starter 的功能和作用 在开发自定义 Starter 之前,需要先确定该 Starter 的功能和作用。例如,自定义 Starter 可以用来统一管理日志、配置数据源、集成第三方组件等。 在这个例子中,我们将自定义 Sta…

    Java 2023年6月2日
    00
  • jsp filter 过滤器功能与简单用法示例

    下面我将为你详细讲解“JSP Filter 过滤器功能与简单用法示例”的完整攻略。 1. JSP Filter 过滤器的概念 JSP Filter 是 JSP 技术中的一种过滤器,它可以以拦截器的方式截获请求,对请求进行过滤或者添加处理,再将请求交给被请求的资源处理,从而实现某些特定的功能和保障系统的安全性。 2. JSP Filter 过滤器的应用场景 J…

    Java 2023年6月15日
    00
  • 使用jackson实现对象json之间的相互转换(spring boot)

    下面是使用Jackson库实现对象和JSON格式的相互转换的完整攻略。 前置条件 本文需要你已经掌握Spring Boot框架的基础知识,并且对于Java对象与JSON的基础知识有所了解。 介绍 Jackson是一个Java库,用于将Java对象序列化为JSON格式的字符串,并将JSON格式的字符串反序列化为Java对象。Jackson支持在Java对象和J…

    Java 2023年5月26日
    00
  • 源码分析SpringMvc日志打印被忽略输出问题

    源码分析SpringMvc日志打印被忽略输出问题 在 Spring MVC 中,我们可以使用日志打印来记录应用程序的运行情况。但是,有时候我们会发现日志打印被忽略输出,本文将详细讲解这个问题的原因和解决方法,并提供两个示例说明。 1. 原因分析 在 Spring MVC 中,日志打印是通过 Log4j、Logback 或者其他日志框架来实现的。如果日志打印被…

    Java 2023年5月18日
    00
  • java实现数组中的逆序对

    首先,让我们先来了解逆序对的概念。逆序对是指在一个数组a中,对于任意两个元素a[i]和a[j],当且仅当ia[j]时,就称这两个元素是一个逆序对。 为了实现数组中的逆序对,我们可以采用归并排序的思路,利用分治算法的思想来实现。 具体的实现过程如下: 将数组从中间分成两个子数组,递归地对两个子数组进行排序,直到每个子数组只剩下一个元素。 然后将两个子数组合并成…

    Java 2023年5月26日
    00
  • Java中try catch处理异常示例

    下面就是“Java中try catch处理异常示例”的详细讲解。 1. 什么是异常? 在Java程序运行过程中,可能会遇到一些非正常的情况,例如读取文件时文件不存在、网络连接异常等等,这些非正常的情况被称为“异常”。 Java中的异常是Throwable类及其子类的实例,可分为检查型异常和非检查型异常(也叫运行时异常)。其中,检查型异常必须显式处理,而非检查…

    Java 2023年5月28日
    00
合作推广
合作推广
分享本页
返回顶部