
2020-07-18:给定一个无序数组和一个目标值,找出数组中两个数之和等于目标值的所有组合,并指出其时间复杂度。
发布日期:2021-05-04 19:59:07
浏览次数:20
分类:精选文章
本文共 1287 字,大约阅读时间需要 4 分钟。
福哥答案2020-07-18:
假设数组是[3,5,3,5],目标值是8。答案是否可重复,题里没说,所以分3种情况。如下:
1.重复。答案是【0,1】【0,3】【1,2】【2,3】,序号组合,共4种组合。
解法如下: 1.1.嵌套遍历。时间复杂度:O(n^2)。 1.2.哈希法。键存数组元素值,值存出现次数。时间复杂度:O(n)。 1.3.排序+双指针夹逼。时间复杂度:O(nlogn)。2.半重复。答案是【0,1】【2,3】,也可能是【0,3】【1,2】,序号组合,共2种组合。
解法如下: 2.1.嵌套遍历。时间复杂度:O(n^2)。 2.2.哈希法。键存数组元素值,值存出现次数。时间复杂度:O(n)。 2.3.排序+双指针夹逼。时间复杂度:O(nlogn)。3.不重复。答案是[3,5],值组合,共1种组合。
解法如下: 3.1.嵌套遍历。时间复杂度:O(n^2)。 3.2.哈希法。键存数组元素值,值不存。时间复杂度:O(n)。 3.3.排序+双指针夹逼。时间复杂度:O(nlogn)。 3.4.位图法。时间复杂度:O(目标值)。代码采用3.2方式,用golang语言编写。代码如下:
package mainimport "fmt"func main() { nums := []int{ 3, 5, 3, 5, 4, 4} target := 8 for k, _ := range twoSum(nums, target) { fmt.Println(k, "+", target-k, "=", target) }}func twoSum(nums []int, target int) map[int]struct{ } { map0 := make(map[int]struct{ }) //缓存,哈希保存 ret := make(map[int]struct{ }) //保存结果 for i := 0; i < len(nums); i++ { complement := target - nums[i] //差值 = 目标值-元素值 if _, ok := map0[complement]; ok { //如果字典里有差值,说明已经找到了 if complement < nums[i] { ret[complement] = struct{ }{ } } else { ret[nums[i]] = struct{ }{ } } } //如果字典里没有差值,缓存数组的当前值 map0[nums[i]] = struct{ }{ } } return ret}
执行结果如下:

发表评论
最新留言
留言是一种美德,欢迎回访!
[***.207.175.100]2025年04月08日 20时11分10秒
关于作者

喝酒易醉,品茶养心,人生如梦,品茶悟道,何以解忧?唯有杜康!
-- 愿君每日到此一游!
推荐文章
云计算之路-阿里云上:“黑色30秒”走了,“黑色1秒”来了,真相也许大白了
2021-05-09
云计算之路-阿里云上:奇怪的CPU 100%问题
2021-05-09
云计算之路-阿里云上:2014年6月12日12点IIS请求到达量突降
2021-05-09
上周热点回顾(6.9-6.15)
2021-05-09
上周热点回顾(6.16-6.22)
2021-05-09
上周热点回顾(6.23-6.29)
2021-05-09
上周热点回顾(10.20-10.26)
2021-05-09
上周热点回顾(2.16-2.22)
2021-05-09
上周热点回顾(3.2-3.8)
2021-05-09
[网站公告]3月10日23:00-4:00阿里云SLB升级,会有4-8次连接闪断
2021-05-09
.NET跨平台之旅:借助ASP.NET 5 Beta5的新特性显示CLR与操作系统信息
2021-05-09
上周热点回顾(7.27-8.2)
2021-05-09
上周热点回顾(9.28-10.4)
2021-05-09
[网站公告]数据库服务器IOPS跑满造成网站不能正常访问
2021-05-09
上周热点回顾(3.28-4.3)
2021-05-09
上周热点回顾(5.2-5.8)
2021-05-09
上周热点回顾(5.9-5.15)
2021-05-09
上周热点回顾(8.8-8.14)
2021-05-09
.NET跨平台之旅:将示例站点升级至 .NET Core 1.1 Preview 1
2021-05-09