让我们一起啃算法----两数之和

前言#

工作一段时间之后,最大的感觉就是算法好像没什么用,确实不会算法也能胜任平常的工作,但是总觉得缺了点什么,所以最近抽空复习了以前刷的 Leetcode,希望在这里找到一群志同道合的人:bowtie:

两数之和(Two Sum)#

这是 LeetCode 的第一题,总体来说是比较简单的,题干如下:

给定一个整数数组 nums 和一个目标值 target,请你在该数组中找出和为目标值的那两个整数,并返回他们的数组下标。
示例:
    给定 nums = [2, 7, 11, 15],target = 9
    因为 nums [0] + nums [1] = 2 + 7 = 9
    所以返回 [0, 1]
来源:力扣

简单来说就是给定一个数组,让你找到和为 target 的两个元素的索引。

解题思路#

主要有 两种解题思路

  • 暴力解法:两层循环,外部循环的当前值与 target 的差值为内层循环需要定位的值。时间复杂度 O (n^2),空间复杂度 O (1)。
  • 优雅解法:一层循环,引入 map,循环的当前值与 target 的差值在 map 中查找,如果不存在则将当前值作为键放入 map,值的索引作为 map 的值,存在就返回。时间复杂度 O (n),空间复杂度 O (n)。相比于暴力解法其实就是空间换时间。

代码实现#

暴力解法 GO 实现:#

/*暴力解法
思路:
    两层循环,外部循环的当前值与target的差值为内层循环需要定位的值
*/
func twoSumForce(nums []int, target int) (result []int) {
    length := len(nums)
    if length <= 0 {
        return
    }
    for i := 0; i < length; i++ {
        for j := i + 1; j < length; j++ {
            // 找到了就直接返回
            if nums[j] + nums[i] == target {
                return []int{i,j}
            }
        }
    }
    return
}

优雅解法 GO 实现:#

/*优雅解法
思路:
    一层循环,引入map,循环的当前值与target的差值在map中查找,如果不存在则将当前值作为键放入map,值的索引作为map的值。
*/
func twoSumElegant(nums []int, target int) (result []int) {
    if len(nums) <= 0 {
        return
    }
    var m = make(map[int]int)
    for index, value := range nums {
        if v, ok := m[target-value]; !ok {
            // 将当前值和索引放入map中
            m[value] = index
        } else {
            return []int{index,v}
        }
    }
    return
}

总结#

每天进步一点点,加油!
算法教程项目,每天更新一题,点个 star 支持一下呀
https://github.com/wx-satellite/learning-a...

本作品采用《CC 协议》,转载必须注明作者和本文链接
三斤
《L03 构架 API 服务器》
你将学到如 RESTFul 设计风格、PostMan 的使用、OAuth 流程,JWT 概念及使用 和 API 开发相关的进阶知识。
《L02 从零构建论坛系统》
以构建论坛项目 LaraBBS 为线索,展开对 Laravel 框架的全面学习。应用程序架构思路贴近 Laravel 框架的设计哲学。
讨论数量: 3
function twoSum($nums, $target) {
    $count = count($nums);
    if ($count <= 0) {
        return '';
    }

    $tmp = [];  // 中间交换数组
    for ($i = 0; $i < $count; $i++) {
        // 如果当前值不等于目标值减第一个key的值,则将 $tmp 数组的内容置换为当前值和key
        if ($nums[$i] != $target - array_key_first($tmp)) {
            $tmp = [];
            $tmp[$nums[$i]] = $i;
        } else {
            // 如果匹配,根据 $tmp 当前键的值返回所属 key 和 当前 $i
            return [$tmp[array_key_first($tmp)], $i];
        }
    }

    return [];
}

echo twoSum([1,7,8,5,6], 18); // output: []
echo twoSum([1,7,8,5,6], 15); // output: [1,2]

搞了个 php 的实现

4年前 评论
三斤和他的喵 (楼主) 4年前
幽弥狂 4年前
captain2021 (作者) 4年前
幽弥狂
function twoSum($nums, $target) {
        $data = [];
        foreach($nums as $key => $val) {
            $data[$val] = $key;
        }

        foreach($nums as $k => $v) {
            $dataKey = $target-$v;
            if (isset($data[$dataKey]) && $k != $data[$dataKey]) {
                return [$k, $data[$dataKey]];
            }
        }

        return [];
    }

LeetCode 上最推荐的方式吧

file

4年前 评论

laravel 社区发 Go 不合适吧

4年前 评论
三斤和他的喵 (楼主) 4年前
皮皮强 (作者) 4年前