【数组】两数之和

简介: 【数组】两数之和

1. 题目描述

2. 题目分析

  1. 我们首先想到的,是暴力,直接双重循环,这种的耗费时间为O(n^2),也不是面试官想要看到的,我们需要在此方法的基础上对其改进。
  2. 我们想到了一种数据结构(HashMap),我们知道,对于HashMap而言,它具有(key-value)的一种映射,我们将 target - nums[i] 设置为key,将它的下标i设置为value,这样的话, 当我们在数组中再一次遍历到**target - nums[i]**时,将 value 和当前的下标设置返回
if (map.containsKey(nums[i])) {
        res[0] = map.get(nums[i]);
                res[1] = i;
      } else {
        map.put(target - nums[i], i);
      }

3. 题目代码

class Solution {
   public int[] twoSum(int[] nums, int target) {
    HashMap<Integer, Integer> map = new HashMap<Integer, Integer>();
    int[] res = new int[2];
    for (int i = 0; i < nums.length; i++) {
      if (map.containsKey(nums[i])) {
        res[0] = map.get(nums[i]);
                res[1] = i;
      } else {
        map.put(target - nums[i], i);
      }
    }
    return res;
  }
}


相关文章
|
关系型数据库 MySQL 数据库
数据库与图片完美解决方案
你是是不是在开发中常常遇到,删除了数据库记录后,发现该记录对应的图片没有删除,或者删除了图片,数据库中仍有数据存在,你的网站脏数据(图片)成几何数增长,阅读下文这里为你提供了一个完美决方案。
2017 0
|
3天前
|
人工智能 JavaScript 测试技术
Qwen3-Coder入门教程|10分钟搞定安装配置
Qwen3-Coder 挑战赛简介:无论你是编程小白还是办公达人,都能通过本教程快速上手 Qwen-Code CLI,利用 AI 轻松实现代码编写、文档处理等任务。内容涵盖 API 配置、CLI 安装及多种实用案例,助你提升效率,体验智能编码的乐趣。
282 100
|
3天前
|
JSON fastjson Java
FastJson 完全学习指南(初学者从零入门)
摘要:本文是FastJson的入门学习指南,主要内容包括: JSON基础:介绍JSON格式特点、键值对规则、数组和对象格式,以及嵌套结构的访问方式。FastJson是阿里巴巴开源的高性能JSON解析库,具有速度快、功能全、使用简单等优势,并介绍如何引入依赖,如何替换Springboot默认的JackJson。 核心API: 序列化:将Java对象转换为JSON字符串,演示对象、List和Map的序列化方法; 反序列化:将JSON字符串转回Java对象,展示基本对象转换方法;
|
4天前
|
Android开发 开发者 Windows
这是我设计的一种不关机,然后改造操作系统的软件设计思路2.0版本
本文介绍了在不重启系统的情况下实现操作系统改造的两种方案。第一种方案通过SLFM Recovery模式,在独立于操作系统的最高权限环境下完成系统更新与改造,并支持断电恢复与失败回滚。第二种方案采用多分区机制,通过SLFM套件在独立分区中完成系统改造,适用于可中断与不可中断服务场景,确保系统更新过程的安全与稳定。
225 132
|
4天前
|
缓存 JavaScript 前端开发
JavaScript 的三种引入方法详解
在网页开发中,JavaScript 可通过内联、内部脚本和外部脚本三种方式引入 HTML 文件,各具适用场景。本文详解其用法并附完整示例代码,帮助开发者根据项目需求选择合适的方式,提升代码维护性与开发效率。
193 110

热门文章

最新文章