数据结构与算法之两数之和

#如何求两数之和
问题:

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

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

示例:

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

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

解答:
用暴力法解决,遍历数组中的每个元素x,找到一个是否和target-x相等,然后返回这两个数在数组中的位置就OK了。

class Solution
{
    public int[] TwoSum(int[] nums, int target)
    {
        for (int i = 0; i < nums.Length; i++)
        {
            for (int j = i + 1; j < nums.Length; j++)
            {
                if (nums[j] == target - nums[i])
                {
                    return new int[]
                        {i,j};
                }
            }
        }
        throw new
        ArgumentException("no have two sum solution"); }

}


数据结构与算法之两数之和_第1张图片

你可能感兴趣的:(数据结构与算法之两数之和)