主页 > 知识库 > golang数组-----寻找数组中缺失的整数方法

golang数组-----寻找数组中缺失的整数方法

热门标签:呼叫中心市场需求 铁路电话系统 Linux服务器 AI电销 网站排名优化 地方门户网站 服务外包 百度竞价排名

问题:由n-1个整数组成的未排序数组,元素都是1~n的不同整数,找出其中缺失的整数

方法一:

思路:是原数组的和 减去 丢失元素后的数组的和,就得到丢失的元素了

代码如下:

package main
import (
	"errors"
	"fmt"
)
func getMissingElement(arr []int) int {
	var sumA, sumB int
	if arr == nil || len(arr) = 0 {
		errors.New("空数组")
	}
	for k, v := range arr {
		sumA += v
		sumB += k
	}
	sumB = sumB + len(arr)*2 + 1
	return sumB - sumA
}
func main() {
	var arr []int
	arr = []int{1, 3, 2, 6, 5, 7, 8}
	fmt.Println(getMissingElement(arr))
}

结果:4

补充:golang菜鸟常见的坑----golang切片与数组

切片与数组的区别:

数组(array:=[len]int{})一旦声明定义,便会有固定的长度(len),固定的容量(cap),且数组不能修改长度。

切片(slice:=[]int{})定义之后,长度(len)、容量(cap)可以不固定!

如下图所示:slice s再声明之后还可以追加元素。

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。如有错误或未考虑完全的地方,望不吝赐教。

您可能感兴趣的文章:
  • golang json数组拼接的实例
  • Golang 如何判断数组某个元素是否存在(isset)
  • golang移除数组中重复的元素操作
  • golang将切片或数组根据某个字段进行分组操作
  • golang求连续子数组的最大和实例
  • golang实现整型和字节数组之间的转换操作
  • Golang 如何判断数组某个元素是否存在 (isset)

标签:湖南 仙桃 黄山 铜川 衡水 湘潭 兰州 崇左

巨人网络通讯声明:本文标题《golang数组-----寻找数组中缺失的整数方法》,本文关键词  ;如发现本文内容存在版权问题,烦请提供相关信息告之我们,我们将及时沟通与处理。本站内容系统采集于网络,涉及言论、版权与本站无关。
  • 相关文章
  • 收缩
    • 微信客服
    • 微信二维码
    • 电话咨询

    • 400-1100-266