golang数组-----寻找数组中缺失的整数方法
程序员文章站
2022-07-05 19:55:44
问题:由n-1个整数组成的未排序数组,元素都是1~n的不同整数,找出其中缺失的整数方法一:思路:是原数组的和 减去 丢失元素后的数组的和,就得到丢失的元素了代码如下:package mainimpor...
问题:由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再声明之后还可以追加元素。
以上为个人经验,希望能给大家一个参考,也希望大家多多支持。如有错误或未考虑完全的地方,望不吝赐教。
推荐阅读
-
PHP array_key_exists检查键名或索引是否存在于数组中的实现方法_php实例
-
php中判断数组是一维,二维,还是多维的解决方法_php实例
-
php使用unset()删除数组中某个单元(键)的方法,unset数组_PHP教程
-
php中的一些数组排序方法分享
-
数组中的方法?push(); unshift();pop(); shift();join();concat(); splice(); slice();
-
JavaScript中数组中的方法:push()、pop()、shift()、unshift()、slice()、splice()、reverse()、join()、split()、concat()、...
-
php在多维数组中查找特定的value的方法
-
详解Swift中对C语言接口缓存的使用以及数组与字符串转为指针类型的方法
-
Java中数组转List的三种方法与对比分析
-
Java替换int数组中重复数据的方法示例