算法练习01

devtools/2025/1/8 11:51:53/

一、题目

给定一个整数数组 nums 和一个整数目标值target,请你在该数组 中找出 和为目标值 target 的那 两个整数,并返回它们的数组下标。

你可以假设每种输入只会对应一个答案,并且你不能使用两次相同的元素。 你可以按任意顺序返回答案。

  • 示例 1: 输入:nums =[2,7,11,15],target = 9 输出:[0,1] 解释:因为nums[0]+nums[1]==9,返回[0,1]。
  • 示例 2: 输入:nums=[3,2,4],target =6 输出:[1,2]
  • 示例 3: 输入:nums=[3,3],target =6 输出:[0,1]

 提示: 2<= nums.length <= 10 。-109 <= nums[i]<= 109 -109 <= target <= 109 。

二、实现思路

1.哈希表:使用一个哈希表(HashMap)来存储数组中已经访问过的元素及其对应的下标。
2.遍历数组:对于每个元素,计算目标值与当前元素的差值。
3.查找哈希表:检查差值是否在哈希表中存在。
4.如果存在,说明找到了两个数,它们的和为目标值,返回它们的下标。
5.如果不存在,将当前元素及其下标存入哈希表中。
6.返回结果:如果遍历结束后没有找到符合条件的两个数,则返回空数组(根据题意,这种情况不会发生)。

三、代码实现

package com.thor.test;import java.util.Arrays;
import java.util.HashMap;
import java.util.Map;public class Demo {public static void main(String[] args) {/** 1.需求* 给定一个整数数组 nums 和一个整数目标值target,请你在该数组 中找出 和为目标值 target 的那 两个整数,并返回它们的数组下标。* 你可以假设每种输入只会对应一个答案,并且你不能使用两次相同的元素。 你可以按任意顺序返回答案。* 示例 1: 输入:nums =[2,7,11,15],target = 9 输出:[0,1] 解释:因为nums[0]+nums[1]==9,返回[0,1]。* 示例 2: 输入:nums=[3,2,4],target =6 输出:[1,2]* 示例 3: 输入:nums=[3,3],target =6 输出:[0,1]* 提示: 2<= nums.length <= 10 。-109 <= nums[i]<= 109 -109 <= target <= 109 。* 只会存在一个有效答案** 2.实现思路* 哈希表:使用一个哈希表(HashMap)来存储数组中已经访问过的元素及其对应的下标。* 遍历数组:对于每个元素,计算目标值与当前元素的差值。* 查找哈希表:检查差值是否在哈希表中存在。* 如果存在,说明找到了两个数,它们的和为目标值,返回它们的下标。* 如果不存在,将当前元素及其下标存入哈希表中。* 返回结果:如果遍历结束后没有找到符合条件的两个数,则返回空数组(根据题意,这种情况不会发生)。* *///测试第一组int[] nums = {2,7,11,15};int target = 9;int[] result = twoSum(nums,target);System.out.println(Arrays.toString(result));//测试第二组int[] nums1={3,2,4};int target1=6;int[] result1= twoSum(nums1,target1);System.out.println(Arrays.toString(result1));//测试第三组int[] nums2={3,3};int target2=6;int[] result2= twoSum(nums2,target2);System.out.println(Arrays.toString(result2));}public  static int[] twoSum(int[] nums ,int target){//创建一个哈希表,用于存储已经访问过的元素以及其对应的下标Map<Integer, Integer> numMap = new HashMap<>();//遍历数组for(int i=0;i<nums.length;i++){//计算目标值与当前元素的差值int complement=target-nums[i];//检查差值是否存在哈希表中if(numMap.containsKey(complement)){//存在,说明找到了两个数,和为目标值,返回它们的下标return new int[]{numMap.get(complement),i};}//不存在,将当前元素及下标存在哈希表中numMap.put(nums[i],i);}//遍历结束后,没有找到符合条件的两个数,返回空数组return new int[] {};}
}

http://www.ppmy.cn/devtools/148883.html

相关文章

恒功率反激式控制器 CRE6281G

CRE6281G 为高性能多模式 PWM 反激式控制器,CRE6281G特征有&#xff1a;  内置软启动功能  CRE6281G内置线电压补偿&#xff08;OCP&#xff09;  内置斜坡补偿  改善电磁干扰的智能抖频技术  超低启动电流  高杂讯抗干扰能力  多模式控制  CRE6281G恒功率输出…

极客说|微软 Phi 系列小模型和多模态小模型

作者&#xff1a;胡平 - 微软云人工智能高级专家 「极客说」 是一档专注 AI 时代开发者分享的专栏&#xff0c;我们邀请来自微软以及技术社区专家&#xff0c;带来最前沿的技术干货与实践经验。在这里&#xff0c;您将看到深度教程、最佳实践和创新解决方案。关注「极客说」&am…

期末概率论总结提纲(仅适用于本校,看文中说明)

文章目录 说明A选择题1.硬币2.两个事件的关系 与或非3.概率和为14.概率密度 均匀分布5.联合分布率求未知参数6.联合分布率求未知参数7.什么是统计量&#xff08;记忆即可&#xff09;8.矩估计量9.117页12题10.显著水平阿尔法&#xff08;背公式就完了&#xff09; 判断题11.事件…

LLM加速方法,Adapter Tuning和Prompt Tuning的区别及原理举例

LLM加速方法 目录 LLM加速方法整体结构各分支内容Adapter Tuning和Prompt Tuning的区别及原理举例一、区别二、总结整体结构 基于模型微调、基于模型压缩、基于分布式并行处理。 各分支内容 基于模型微调: 包含Adapter Tuning、Prompt Tuning、LoRA三个子类别。这些技术主要…

甘肃省乡镇界arcgis格式shp数据乡镇名称和编码下载内容测评

标题中的“甘肃省乡镇界arcgis格式shp数据乡镇名称和编码2020年最新”表明这是一份关于甘肃省乡镇行政边界的地理信息数据。这些数据以Esri公司的GIS&#xff08;地理信息系统&#xff09;软件ArcGIS所支持的SHP&#xff08;Shapefile&#xff09;格式提供&#xff0c;并且包含…

linux 设置mysql 外网访问

1、修改 MySQL 配置文件 找到并编辑配置文件&#xff1a;在Linux系统中&#xff0c;MySQL的配置文件通常是/etc/mysql/my.cnf&#xff0c;使用命令sudo vim /etc/mysql/my.cnf打开文件。 注释或修改 bindaddress&#xff1a;找到bindaddress 127.0.0.1&#xff0c;将其注释掉…

Nginx:SSL/TLS 配置

HTTPS 协议简单来说就是“HTTP 协议”和“SSL/TLS 协议”的组合。 HTTPS 工作流程图描述 1. 客户端发起 HTTPS 请求 说明:用户在浏览器中输入一个 HTTPS URL 或点击一个 HTTPS 链接。浏览器会向指定的服务器发起一个 HTTPS 请求。 [客户端] --发起HTTPS请求--> [DNS服务器…

基于Arduino的FPV头部追踪相机系统

构建FPV头部追踪相机&#xff1a;让你置身于遥控车辆之中&#xff01; 在遥控车辆和模型飞行器的世界中&#xff0c;第一人称视角&#xff08;FPV&#xff09;体验一直是爱好者们追求的目标。通过FPV头部追踪相机&#xff0c;你可以像坐在车辆或飞行器内部一样&#xff0c;自由…