Go 数组

一、数组介绍

1、Array 介绍
  • 数组是指一系列同一类型数据的集合
  • 数组中包含的咩个数据被成为数组元素(element),这种类型可以是任意的原始类型,比如 int、string 等
  • 一个数组包含的元素格式被称为数组的长度
  • 在 Golang 中数组是一个长度固定的数据类型,数组的长度是类型的一部分,也就是[5]int和[10]int 是两个不同的类型
  • Golang 中数组的另一个特点是占用内存的连续性,也就是说数组中的元素是被分配到连续的内存地址中的, 因而索引数组元素的速度非常快
  • 和数组对应的类型是 Slice(切片),Slice 是可以增长和收缩的动态序列,功能也更灵活
  • 但是想要理解 slice 工作原理的话需要先理解数组,下面为大家讲解数组的使用
2、数组定义

var 数组变量名[元素数量]T

  • 比如:var a [5]int,数组的长度必须是常量,并且长度是数组类型的一部分
  • 一旦定义,长度不能变,[5]int和[4]int 是不同的类型
Go 复制代码
package main

import "fmt"

func main() {
    //定义一个长度为 3 元素类型为 int 的数组 a
    var a [3] int
    //定义一个长度为 3 元素类型为 int 的数组 b 并赋值
    var b [3] int
    b[0] = 60
    b[1] = 80
    b[2] = 100
    fmt.PrintIn(a)    //[0 0 0]
    fmt.Print(b)    //[60,80,100]
}
3、数组是值类型
  • 数组是值类型,赋值和传参会复制整个数组
  • 因此改变副本的值,不会改变本身的值
  • 注意:
    • 数组支付"=="、"!="操作符,因为内存总是被初始化过的
    • [n]*T表示指针数组,*[n]T表示数组指针
Go 复制代码
package main

import "fmt"

func main(){
    a :=[3]int{10,20,30}
    modifyArray(a)    //在 modify 中修改的是 a 的副本 x
    fmt.PrintIn(a)    //[10,20,30]
}
func modifyArray(x [3]int){
    x[0] = 100
}

二、创建数组

1、自定义数组长度
Go 复制代码
package main

import "fmt"

func main(){
    // 1数组会初始化为 int 类型的零值
    var testArray [3] int
    fmt.PrintIn(testArray)    //[0 0 0]
    
    //2.使用指定的初始值完成初始化
    var numArray = [3]int{1,2}
    fmt.printIn(numArray)    //[1 2 0]

    var cityArray = [3]string{"北京","上海","深圳"}
    fmt.Println(cityArray)    //[北京 上海 深圳]
}
2、让编译器识别
  • 按照上面的方法每次都要确保提供的初始值和数组长度一致
  • 一般情况下我们可以让编译器根据初始值的个数自行推断数组的长度
Go 复制代码
package main

import "fmt"

func main(){
    var numArray = [...]int{1,2}
    fmt.PrintIn(numArray)    //[1 2]
    fmt.Printf("type of numArray:%T\n",numArray)    //type of numArray:[2]int

    var cityArray = [...]string{"北京","上海","深圳"}
    fmt.PrintIn(cityArray)    //[北京 上海 深圳]
    fmt.Printf("type of cityArray:%T\n", cityArray)  //type of cityArray:[3]string
}
3、指定索引值
  • 我们还可以使用指定索引值的方式来初始化数组
Go 复制代码
package main

import "fmt"

func main() {
	// 初始化一个整数数组,在下标1号和3号位置写入: 1   5
	a := [...]int{1: 1, 3: 5}
	fmt.Println(a)    // [0 1 0 5]
	fmt.Printf("type of a:%T\n", a)    //type of a:[4]int
}

三、数组的遍历

1、普通遍历数组
Go 复制代码
package main

import "fmt"

func main() {
	var a = [...]string{"北京", "上海", "深圳"}
	for i := 0; i < len(a); i++ {
		fmt.Println(a[i])
	}
}
/*
北京
上海
深圳
 */
2、k,v遍历数组
Go 复制代码
package main

import "fmt"

func main() {
	var a = [...]string{"北京", "上海", "深圳"}
	for index, value := range a {
		fmt.Println(index, value)
	}
}
/*
0 北京
1 上海
2 深圳
 */

四、多维数组

1、定义多维数组
Go 复制代码
package main

import "fmt"

func main() {
	a := [3][2]string{
		{"北京", "上海"},
		{"广州", "深圳"},
		{"成都", "重庆"},
	}
	fmt.Println(a)         //[[北京 上海] [广州 深圳] [成都 重庆]]
	fmt.Println(a[2][1])     //支持索引取值:重庆
}

2、遍历多维数组

Go 复制代码
package main
import "fmt"
func main() {
	a := [3][2]string{
		{"北京", "上海"},
		{"广州", "深圳"},
		{"成都", "重庆"},
	}
	for _, v1 := range a {   // v1 = [北京 上海]
		for _, v2 := range v1 {
			fmt.Println(v2)
		}
	}
}
/*
北京
上海
广州
深圳
成都
重庆
*/

五、数组练习

1、数组求和
Go 复制代码
package main

import "fmt"

func main() {
    var intArr2[5]int=[...]int{1,-1,9,90,12}
    sum := 0
    for _,val := range intArr2{
        //累计求和
        sum += val
    }
    
    //如何让平均值保留到小数
	fmt.Printf("sum=%v 平均值=%v \n\n", sum, float64(sum) / float64(len(intArr2)))
	// sum=111 平均值=22.2 
}
2、数组最大值
  • 声明一个数组 var intArr[5] = [...]int {1,-1,112,65,11}
  • 假定第一个元素就是最大值 下标就是 0
  • 然后从第二个元素开始循环比较,如果发现更嘎,则交换
Go 复制代码
package main
import "fmt"
func main() {
	var intArr = [...]int{1, -1, 112, 65, 11}
	maxValue := intArr[0]
	maxIndex := 0
	for i := 0; i < len(intArr); i++ {
		if maxValue < intArr[i] {
			maxValue = intArr[i]
			maxIndex = i
		}
	}
	fmt.Println("最大值", maxValue, "最大值索引值", maxIndex)
	// 最大值 112 最大值索引值 2
}
相关推荐
千天夜6 分钟前
多源多点路径规划:基于启发式动态生成树算法的实现
算法·机器学习·动态规划
从以前12 分钟前
准备考试:解决大学入学考试问题
数据结构·python·算法
.Vcoistnt35 分钟前
Codeforces Round 994 (Div. 2)(A-D)
数据结构·c++·算法·贪心算法·动态规划
ALISHENGYA1 小时前
全国青少年信息学奥林匹克竞赛(信奥赛)备考实战之分支结构(实战训练三)
数据结构·c++·算法·图论
我码玄黄3 小时前
正则表达式优化之算法和效率优化
前端·javascript·算法·正则表达式
Solitudefire4 小时前
蓝桥杯刷题——day9
算法·蓝桥杯
三万棵雪松5 小时前
1.系统学习-线性回归
算法·机器学习·回归·线性回归·监督学习
Easy数模5 小时前
基于LR/GNB/SVM/KNN/DT算法的鸢尾花分类和K-Means算法的聚类分析
算法·机器学习·支持向量机·分类·聚类
xiaocaibao7775 小时前
编程语言的软件工程
开发语言·后端·golang
2401_858286115 小时前
117.【C语言】数据结构之排序(选择排序)
c语言·开发语言·数据结构·笔记·算法·排序算法