从 Two Sum 快学 Go 基础语法

两数之和最容易想到的方法是通过暴力枚举 ,通过嵌套循环的方式枚举数组中每一个 x,在剩余元素中是否存在 target-x

Go 复制代码
func twoSum(nums []int, target int) []int {
    length := len(nums)
    for i :=0; i < length; i++ {
        for j := i+1; j < length; j++ {
             v_s := nums[i]
             v_c := nums[j]
            if v_c + v_s == target {
                return []int{i, j}
            }
        }
    }
    return nil
}

从代码中,涉及到变量的定义、循环和条件判断。

变量的定义与初始化

基础类型变量:

Go 复制代码
// 声明: var [变量名] [数据类型]
var x int 
// 赋值:[变量名] = [具体值]
x = 5

// 简写:[变量名] := [具体值]
y := 6

数组类型:

Go 复制代码
// 声明:var [变量名] [数组长度] [数据类型]
var arr [2]int
// 赋值:[变量名][数组下标] = [具体值]
arr[0] = -1

// 简写:[变量名] := [数组长度][数据类型]{具体值}
arr2:= [2]int{-1, 1}

对于声明与定义变量,JavaScript 习惯性的用 const 修饰 length ,在这里是不被允许的。为什么呢,Go 作为强类型的静态语言要求 length 的值在编译时确认 ,而不是在运行时期,因此无法length 视作常量。

循环与条件控制

此处 Go 与 JavaScript 基本相似,主要区别是 Go 不需要括号包裹判断条件。


暴力枚举法的时间复杂度过高,可以考虑哈希表法 用空间换时间。创建哈希表后,对于数组中每一个 x 都检查哈希表中是否存在 target -x

Go 复制代码
func twoSum(nums []int, target int) []int {
    set := make(map[int]int)
    for i :=0; i < length; i++ {
        idx, res := set[target - nums[i]]
        if res {
            return []int{i, idx}
        }
        set[nums[i]] = i
    }
    return nil
}

此时,出现了新知识点哈希表的使用

哈希表

Go 称之为映射,且需要通过内置的 make 函数创建

Go 复制代码
// 初始化 [变量名] := make(map[key数据类型][value数据类型])
m := make(map[string]int)

// 插入 
m["a"] = 1

// 判断 key 存在
value, ok := m["c"] // ok: boolean,key 存在则为 true

小结

边学边练,日拱一卒!我们已经从 twosum 中学习到 Go 中关于变量的定义和初始化、循环和条件控制以及哈希表的使用啦。

相关推荐
2401_872418785 小时前
算法入门:数据结构-堆
数据结构·算法
xwz小王子6 小时前
手术机器人登上Science Robotics:2毫米纤细手臂,从3厘米切口完成腰椎神经减压
算法·机器人
黎阳之光7 小时前
视频孪生智护供水生命线:黎阳之光赋能医疗与园区水务高质量升级
运维·物联网·算法·安全·数字孪生
Black蜡笔小新8 小时前
自动化AI算法训练服务器DLTM制造业AI质检工作站助力制造业实现AI智检
人工智能·算法·自动化
嵌入式小能手8 小时前
飞凌嵌入式ElfBoard-进程间的通信之命名管道
linux·服务器·算法
啦哈拉哈8 小时前
Leetcode题解记录-hot100(81-100)
算法·leetcode·职场和发展
csdn_aspnet8 小时前
Java 霍尔分区算法(Hoare‘s Partition Algorithm)
java·开发语言·算法
诸葛务农8 小时前
道路行驶条件下电动汽车永磁电机的有效使用寿命及永磁体的失效和回收再利用(下)
java·开发语言·算法
snow@li8 小时前
AI:理解 大数据、算法、算力、电力、生成式AI、token 之间的关系
大数据·人工智能·算法
小智老师PMP9 小时前
零基础能不能考PMP?零基础专属学习路径+全套扶持体系
学习·算法·职场和发展·软件工程·求职招聘·敏捷流程