两数之和
描述
给出一个整型数组 numbers 和一个目标值 target,请在数组中找出两个加起来等于目标值的数的下标,返回的下标按升序排列。
(注:返回的数组下标从1开始算起)
数据范围:,,
要求:空间复杂度 O(n),时间复杂度
例如:
给出的数组为 [20, 70, 110, 150] , 目标值为90
返回一个数组 [1,2] ,因为
- Java实现
1 import java.util.*;
2 public class Solution { 3 /** 4 * 5 * @param numbers int整型一维数组 6 * @param target int整型 7 * @return int整型一维数组 8 */ 9 public int[] twoSum (int[] numbers, int target) { 10 HashMap map=new HashMap<>(); 11 for(int i=0,len=numbers.length;i<len;i++){ 12 if(map.containsKey(target-numbers[i])) 13 return new int[]{map.get(target-numbers[i]), i+1}; 14 else 15 map.put(numbers[i],i+1); 16 } 17 return new int[]{}; 18 } 19 }
- C#实现
1 using System;
2 using System.Collections.Generic; 3 class Solution { 4 /** 5 * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可 6 * @param numbers int整型一维数组 7 * @param target int整型 8 * @return int整型一维数组 9 */ 10 public List twoSum (List numbers, int target) { 11 Dictionary<int, int> dict = new Dictionary<int, int>(); 12 for(int i=0,len=numbers.Count;i<len;i++){ 13 if(dict.ContainsKey(target-numbers[i])) 14 return new List(){dict.GetValueOrDefault(target-numbers[i]), i+1}; 15 else 16 dict.Add(numbers[i], i+1); 17 } 18 return new List(); 19 } 20 }
__EOF__

本文作者:始是逍遥人
本文链接:https://www.cnblogs.com/brucewang92/p/15659905.html
关于博主:评论和私信会在第一时间回复。或者直接私信我。
版权声明:本博客所有文章除特别声明外,均采用 BY-NC-SA 许可协议。转载请注明出处!
声援博主:如果您觉得文章对您有帮助,可以点击文章右下角【推荐】一下。您的鼓励是博主的最大动力!
本文链接:https://www.cnblogs.com/brucewang92/p/15659905.html
关于博主:评论和私信会在第一时间回复。或者直接私信我。
版权声明:本博客所有文章除特别声明外,均采用 BY-NC-SA 许可协议。转载请注明出处!
声援博主:如果您觉得文章对您有帮助,可以点击文章右下角【推荐】一下。您的鼓励是博主的最大动力!
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· 单线程的Redis速度为什么快?
· SQL Server 2025 AI相关能力初探
· AI编程工具终极对决:字节Trae VS Cursor,谁才是开发者新宠?
· 展开说说关于C#中ORM框架的用法!