题目概述
- 算法说明
输入一个递增排序的数组和一个数字S,在数组中查找两个数,使得他们的和正好是S,如果有多对数字的和等于S,输出两个数的乘积最小的。 - 测试用例
对应每个测试案例,输出两个数,小的先输出。
输入:
[1,2,4,7,11,15],15
输出:
[4,11]
解析&参考答案
- 解析
方法1: 2个for循环遍历,记录满足条件最小的两个数即可,时间复杂度较高;
方法2: 使用一个for循环,2个指针分别指向最左和最右,依次向中间夹逼,第一个符合要求的即为目标数(两个数字间距越大,其乘积越小)。 - 参考答案
vim jz42.go
package main
import "fmt"
func FindNumbersWithSum(array []int, sum int) []int {
var result []int
if array == nil || len(array) < 2 {
return result
}
left, right := 0, len(array)-1
for left < right {
tmp := array[left] + array[right]
if tmp == sum {
result = []int{array[left], array[right]}
break
} else if tmp > sum {
right--
} else if tmp < sum {
left++
}
}
return result
}
func main() {
array := []int{1, 2, 4, 7, 11, 15}
sum := 15
result := FindNumbersWithSum(array, sum)
fmt.Println(result)
}
注意事项
说明
- 当前使用 go1.15.8
- 参考 牛客网--剑指offer
标题中jzn(n为具体数字)代表牛客网剑指offer系列第n号题目,例如 jz01 代表牛客网剑指offer中01号题目。
注意!!!
- 笔者最近在学习 golang,因此趁机通过数据结构和算法来进一步熟悉下go语言
- 当前算法主要来源于剑指 offer,后续会进一步补充 LeetCode 上重要算法,以及一些经典算法
- 此处答案仅为参考,不一定是最优解,欢迎感兴趣的读者在评论区提供更优解