go语言数组使用

文章目录

数组定义

定义方式1

func main() {
	var emptyArrWithDefaultEle [3]int // 定义大小为3的空数组
	var emptyArr []int				  // 定义大小为0的空数组
	fmt.Println("打印emptyArrWithDefaultEle: ", emptyArrWithDefaultEle)
	fmt.Println("打印emptyArr:", emptyArr)
}

输出如下

打印emptyArrWithDefaultEle:  [0 0 0]
打印emptyArr: []

定义方式2

func main() {
	arr1 := [...]int{1,2,3} 
	arr2 := [...]int{1:12, 2:13, 5:5} // 给下标为1的元素赋值12,下标为2的元素赋值13,下标为5的元素赋值5
	fmt.Println("打印arr1: ", arr1)
	fmt.Println("打印arr2:", arr2)
}

输出如下

打印arr1:  [1 2 3]
打印arr2: [0 12 13 0 0 5]

特殊情况

func main() {
	arr3 := [...]int{1,2,3, 0:6} // 同一个索引不允许重复赋值
    fmt.Println("打印arr3:", arr3)
}

输出如下

duplicate index 0 in array or slice literal

定义方式3

func main() {
	arr := make([]int, 3, 3) // 第一个参数为数组类型,3为数组大小size,6为容量
	arr[0] = 1
	arr[1] = 2
	arr[2] = 3
	fmt.Println("打印数组arr:", arr)
	arr = append(arr, 4) // append为数组追加,会自动扩容
	arr = append(arr, 5)
	arr = append(arr, 6)
	fmt.Println("打印数组arr:", arr)
}

数组遍历

遍历方式1

在go中,如果定义了变量不使用,编译不会通过,可以使用 "_" 代替

func main() {
	arr := [...]int{5,4,3,2,1}
	// index是下标,value是元素值
	for index, value := range arr {
		fmt.Println("index=", index, "value=",value)
	}
	// 只打印下标
	for index := range arr {
		fmt.Println("index=", index)
	}
	// 只打印元素值
	for _, value := range arr {
		fmt.Println("value=", value)
	}
}

输出

index= 0 value= 5
index= 1 value= 4
index= 2 value= 3
index= 3 value= 2
index= 4 value= 1
index= 0
index= 1
index= 2
index= 3
index= 4
value= 5
value= 4
value= 3
value= 2
value= 1```

遍历方式2

func main() {
 	arr := [...]int{1,2,3}
	for i := 0;i < len(arr);i++ {
		fmt.Println("index:", i, "value:", arr[i])
	}
}

输出

index: 0 value: 1
index: 1 value: 2
index: 2 value: 3
相关推荐
哭泣的眼泪4081 小时前
解析粗糙度仪在工业制造及材料科学和建筑工程领域的重要性
python·算法·django·virtualenv·pygame
Microsoft Word2 小时前
c++基础语法
开发语言·c++·算法
天才在此2 小时前
汽车加油行驶问题-动态规划算法(已在洛谷AC)
算法·动态规划
莫叫石榴姐3 小时前
数据科学与SQL:组距分组分析 | 区间分布问题
大数据·人工智能·sql·深度学习·算法·机器学习·数据挖掘
茶猫_4 小时前
力扣面试题 - 25 二进制数转字符串
c语言·算法·leetcode·职场和发展
Hera_Yc.H5 小时前
数据结构之一:复杂度
数据结构
肥猪猪爸6 小时前
使用卡尔曼滤波器估计pybullet中的机器人位置
数据结构·人工智能·python·算法·机器人·卡尔曼滤波·pybullet
linux_carlos6 小时前
环形缓冲区
数据结构
readmancynn6 小时前
二分基本实现
数据结构·算法
萝卜兽编程6 小时前
优先级队列
c++·算法