从品牌网站建设到网络营销策划,从策略到执行的一站式服务
给定一个整数数组 a,其中1 ≤ a[i] ≤ n (n为数组长度), 其中有些元素出现两次而其他元素出现一次。
找到所有出现两次的元素。
你可以不用到任何额外空间并在O(n)时间复杂度内解决这个问题吗?创新互联专注于定州企业网站建设,响应式网站,商城开发。定州网站建设公司,为定州等地区提供建站服务。全流程定制制作,专业设计,全程项目跟踪,创新互联专业和态度为您提供的服务
示例:
输入:
[4,3,2,7,8,2,3,1]
输出:
[2,3]
题意:关键就是把数组中的元素当成是索引来看就行。如果索引处的数字出现过一次,就给-1,因为只会出现两次,如果第二次再出现,那么对应位置的值就会是小于0的,直接加到结果集中就行。一开始我还想着出现过一次-1,再出现一次再*-1,这样最后再遍历一次找到小于0的即可,但是发现有些问题,有些数字没出现过会被误杀。
O(N)时间,O(1)空间
func findDuplicates(nums []int) []int {
result := make([]int, 0)
for _, v := range nums {
v = int(math.Abs(float64(v)))
if nums[v-1] > 0 {
nums[v-1] = nums[v-1] * -1
} else {
result = append(result, v)
}
}
return result
}
成都网站建设公司地址:成都市青羊区太升南路288号锦天国际A座10层 建设咨询028-86922220
成都快上网科技有限公司-四川网站建设设计公司 | 蜀ICP备19037934号 Copyright 2020,ALL Rights Reserved cdkjz.cn | 成都网站建设 | © Copyright 2020版权所有.
专家团队为您提供成都网站建设,成都网站设计,成都品牌网站设计,成都营销型网站制作等服务,成都建网站就找快上网! | 成都网站建设哪家好? | 网站建设地图