内容简介:一、数组 array声明数组时,必须声明数组大小,声明后大小不可变,未赋值的空间默认值为数组存储类型的 0 值。2.数组遍历
一、数组 array
声明数组时,必须声明数组大小,声明后大小不可变,未赋值的空间默认值为数组存储类型的 0 值。
-
数组是值类型数据,相同空间大小的数组可以用
==
来比较是否相同。
package main import "fmt" func main() { var a1 = [2]int{1, 2} var a2 = [2]int{1, 2} fmt.Println(a1 == a2) // 输出:true }
2.数组遍历
package main import "fmt" func main() { // range 推荐 arr := [3]string{"aa", "bb", "cc"} for index, v := range arr { fmt.Printf("index:%d, value:%s\n", index, v) } // for for i := 0; i < len(arr); i++ { v := arr[i] fmt.Printf("index:%d, value:%s\n", i, v) } }
3.数组追加元素
数组大小固定,所以只能指定元素操作。
package main import ( "fmt" ) func main() { var arr = [5]int{1, 2} arr[2] = 3 arr[3] = 4 fmt.Println(arr) // 输出:[1 4 3 4 0] }
4.数组指针
package main import ( "fmt" ) func main() { // 数组指针之间的赋值不会拷贝底层数组的值 var a1 = &[3]int{1, 2, 3} // 取数组地址 var a2 *[3]int // 定义一个数组指针 a2 = a1 // 使 a2 指向 a1 地址 a1[2] = 9 fmt.Println(*a1) // 输出:[1 2 9] fmt.Println(*a2) // 输出:[1 2 9] }
二、切片 slice
切片可以看作是一个可变长的数组,是一个引用类型。它包含三个数据:1.指向数组的指针,2.切片中的元素,3.切片的大小。
1.切片遍历
package main import "fmt" func main() { sl := []int{1, 2, 3} // range for i, v := range sl { fmt.Printf("index:%d, value:%d\n", i, v) } for i := 0; i < len(sl); i++ { v := sl[i] fmt.Printf("index:%d, value:%d\n", i, v) } }
2.插入、删除元素
只要内存足够,切片可以追加任意个元素。
package main import "fmt" func main() { // 切片末尾追加元素 sl := make([]int, 0) sl = append(sl, 1) sl = append(sl, 2, 3) fmt.Println(sl) // 输出:[1 2 3] // 在索引位置 i 插入元素 x:s = append(s[:i], append([]T{x}, s[i:]...)...) // 在索引位置 1 插入元素 4: sl = append(sl[:1], append([]int{4}, sl[1:]...)...) fmt.Println(sl) // 输出:[1 4 2 3] // 在索引位置 i 插入长度为 j 的切片:s = append(s[:i], append(make([]T, j), s[i:]...)...) // 在索引位置 2 插入长度为 3 的切片: var sl1 = []int{11, 22, 33} sl = append(sl[:2], append(sl1, sl[2:]...)...) fmt.Println(sl) // 输出:[1 4 11 22 33 2 3] // 删除索引位置 i 上元素:s = append(s[:i], s[i+1:]...) // 删除索引位置 1 上的元素: sl = append(sl[:1], sl[1+1:]...) fmt.Println(sl) // 输出:[1 11 22 33 2 3] // 删除索引位置 i 到 j 上的元素,杀出元素不包括索引 j 上的元素:s = append(s[:i],s[j:]...) // 删除索引位置 2 到 4 上的元素: sl = append(sl[:2], sl[4:]...) fmt.Println(sl) // 输出:[1 11 2 3] // 复制切片,将 a 切片上的元素拷贝到 b 切片上:copy(b, a) // 如果切片长度不等,a 长度大于 b 则拷贝len(b) 长度个 a 切片中的元素给 b // 如果 a 长度小于 b 则拷贝 a 中元素到 b 中,b 中超出的元素部分保持原值不变 var a, b []int a = []int{1, 2, 3, 4} b = []int{11, 22} copy(b, a) fmt.Println(b) // 输出:[1,2] c := make([]int, 5) c = []int{11, 22, 33, 44, 55} copy(c, a) fmt.Println(c) // 输出:[1 2 3 4 55] }
3.排序
Go 语言 sort 包提供了 sort.Ints() 、sort.Float64s() 和 sort.Strings() 函数,都是从小到大排序:
package main import ( "fmt" "sort" ) func main() { intList := []int{5, 3, 2, 1, 4} float64List := []float64{5.1, 1.2, 2.34, 4.22, 3.12} stringList := []string{`a`, `e`, `d`, `c`, `b`} // 正序,从小到大排序 sort.Ints(intList) sort.Float64s(float64List) sort.Strings(stringList) fmt.Println(intList) // 输出:[1 2 3 4 5] fmt.Println(float64List) // 输出:[1.2 2.34 3.12 4.22 5.1] fmt.Println(stringList) // 输出:[a b c d e] // 倒叙,从大到小排序 sort.Sort(sort.Reverse(sort.IntSlice(intList))) sort.Sort(sort.Reverse(sort.Float64Slice(float64List))) sort.Sort(sort.Reverse(sort.StringSlice(stringList))) fmt.Println(intList) // 输出:[5 4 3 2 1] fmt.Println(float64List) // 输出:[5.1 4.22 3.12 2.34 1.2] fmt.Println(stringList) // 输出:[e d c b a] }
三、字典 map
字典操作:
package main import "fmt" func main() { m := make(map[string]int, 2) // 插入元素 m["a"] = 11 m["b"] = 22 // 遍历 map for index, v := range m { fmt.Printf("index:%s v%d:\n", index, v) } // 删除 map 中数据 delete(m, "a") fmt.Println(m) // 输出:map[b:22] }
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网
猜你喜欢:本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
计算机算法设计与分析
王晓东 / 电子工业出版社 / 2007-5 / 29.50元
《计算机算法设计与分析(第3版)》为普通高等教育“十一五”国家级规划教材,是计算机专业核心课程“算法设计与分析”教材。全书以算法设计策略为知识单元,系统介绍计算机算法的设计方法与分析技巧。主要内容包括:算法概述、递归与分治策略、动态规划、贪心算法、回溯法、分支限界法、随机化算法、线性规划与网络流、NP完全性理论与近似算法等。书中既涉及经典与实用算法及实例分析,又包括算法热点领域追踪。 为突出......一起来看看 《计算机算法设计与分析》 这本书的介绍吧!