两数之和

描述

给出一个整型数组 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 }

 

posted @ 2021-12-08 16:29  始是逍遥人  阅读(55)  评论(0编辑  收藏  举报