C#算法之两数之和

C#算法之两数之和

题目

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

你可以假设每种输入只会对应一个答案。但是,你不能重复利用这个数组中同样的元素。

示例:

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

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

提示:不能自身相加。

测试用例

[2,7,11,15]

9

预期结果

[0,1]

 格式模板

public class Solution { public int[] TwoSum(int[] nums, int target) {     /*     代码     */ } } 笔者的代码,仅供参考

使用暴力方法,运行时间 700ms-1100ms

public class Solution { public int[] TwoSum(int[] nums, int target) { int [] a = new int[2]; for (int i = 0; i < nums.Length - 1; i++) { for (int j = i + 1; j < nums.Length; j++) { if (nums[i] + nums[j] == target) { a[0] = i; a[1] = j; } } } return a; } }

运行时间 400ms-600ms

由于使用的是哈希表,所以缺点是键不能相同。

public class Solution { public int[] TwoSum(int[] nums, int target) { int[] a = new int[2]; System.Collections.Hashtable hashtable = new System.Collections.Hashtable(); for(int i = 0; i < nums.Length; i++) { hashtable.Add(nums[i], i); } for(int i = 0; i < nums.Length; i++) { int complement = target - nums[i]; if (hashtable.ContainsKey(complement) && int.Parse(hashtable[complement].ToString())!=i) { a[0] = i; a[1] = int.Parse(hashtable[complement].ToString()); } } return a; } }

还是哈希表,缺点是哈希表存储的类型是object,获取值时需要进行转换。

public int[] TwoSum(int[] nums, int target) { int[] a = new int[2]; System.Collections.Hashtable h = new System.Collections.Hashtable(); for (int i = 0; i < nums.Length; i++) { int c = target - nums[i]; if (h.ContainsKey(c)) { a[0] = int.Parse(h[c].ToString()) <= nums[i] ? int.Parse(h[c].ToString()) : i; a[1] = int.Parse(h[c].ToString()) > nums[i] ? int.Parse(h[c].ToString()) : i; } else if (!h.ContainsKey(nums[i])) { h.Add(nums[i], i); } } return a; } 抄一下别人的 public class Solution { public int[] TwoSum(int[] nums, int target) { int[] res = {0, 0}; int len = nums.Length; Dictionary<int, int> dict = new Dictionary<int, int>(); for (int i = 0; i < len; i++) { int query = target - nums[i]; if (dict.ContainsKey(query)) { int min = (i <= dict[query]) ? i : dict[query]; int max = (i <= dict[query]) ? dict[query] : i; return new int[] { min, max }; } else if (!dict.ContainsKey(nums[i])) { dict.Add(nums[i], i); } } return res; } }

推荐阅读

    上下标快捷键|上下标快捷键怎么打

    上下标快捷键|上下标快捷键怎么打,,上下标快捷键怎么打上标快捷键:首先,选中需要加上标的字符,然后使用Word快捷键“ Ctrl + Shift + (加号)+

    下标快捷键ps|下标快捷键快

    下标快捷键ps|下标快捷键快,,下标快捷键快word下标快捷键怎么用方法/步骤:1.双击打开需要使用快捷键输入下标的word文档。2.选定需要下标

    数列求和快捷键|数组求和快捷键

    数列求和快捷键|数组求和快捷键,,数组求和快捷键1,这是文本型数组直接运算 不可能 除非单个的取出来分割后转数值型,再找相同的X[1],进行X[2

    ai数字下标快捷键|AI文字快捷键

    ai数字下标快捷键|AI文字快捷键,,1. AI文字快捷键ai中把文字全选的方法是:1.电脑打开AI软件。2.要一次性选择所有文字,点击菜单栏中的选择

    下标快捷键技巧|下标快捷键快

    下标快捷键技巧|下标快捷键快,,下标快捷键快win7系统中打数字的上下标方法:一、 使用快捷键。在Word中使用快捷键进行输入,既方便又快捷。1.

    快捷键元符号|符号下标快捷键

    快捷键元符号|符号下标快捷键,,1. 符号下标快捷键一、首先打开Excel表格,鼠标左键拖动选中要更改的文字。二、这时按住Alt键不放,依次输入OE

    电脑十进制算法|十进制的算法教程

    电脑十进制算法|十进制的算法教程,,十进制的算法教程0x10就是十六进制数10,转换为十进制数是16,即10(十六进制) = 16(十进制)。十六进制转换

    ppt中下标快捷键|ppt下标的快捷键

    ppt中下标快捷键|ppt下标的快捷键,,1. ppt下标的快捷键end 键是结束,取消的意思PPT 常用快捷键如下Ctrl + M - 插入一张新的幻灯片Ctrl + D

    foreach的用法c语言和c#

    foreach的用法c语言和c#,数组,遍历,本文目录foreach的用法c语言和c#详细讲解foreach循环的用法C#中的foreach 怎么用啊foreach用法C#中的f

    word如何打下标?字母下标怎么打

    word如何打下标?字母下标怎么打,下标,请点击,本文目录word如何打下标字母下标怎么打在Word中输入下下标(例如:a下标(i下标(1 )) 这里1是i的下标下