一、数据结构

一、 数组

1.1 数组 定义 遍历

go 复制代码
// 遍历数组 传递指针 
func traverse() {
	var b = [...]int{1, 2, 3}   //长度为3 元素为 1 2 3
	var ptr = &b                //ptr是指向数组的指针
	fmt.Println(b[0], b[1])     // 打印数组的前 2 个元素
	fmt.Println(ptr[0], ptr[1]) // 通过数组指针访问数组元素的方式和数组类似
	//1.为了避免复制数组带来的开销,可以传递一个指向数组的指针
	//通过数组指针遍历
	for i, v := range ptr {
		fmt.Printf("a[%d]:%d\n", i, v)
	}

	//2.第一种遍历方式 使用for range 迭代可以保证不会出现数组越界情况
	for i := range b {
		fmt.Printf("a[%d]:%d\n", i, b[i])
	}
	//第二种遍历方式
	for i, v := range b {
		fmt.Printf("a[%d]:%d\n", i, v)
	}
	//第三种遍历方式
	for i := 0; i < len(b); i++ {
		fmt.Printf("a[%d]:%d\n", i, b[i])
	}
	fmt.Printf("---------------------------")

}

// 1.数组定义 
func array() {
	var a [3]int                    //长度为3 全部为0
	var b = [...]int{1, 2, 3}       //长度为3 元素为 1 2 3
	var c = [...]int{2: 3, 1: 2}    //长度为3,元素为 0 2 3
	var d = [...]int{1, 2, 4: 5, 6} //长度为6 元素 1 2 0 0 5 6
	var g [0]int                    // 定义一个长度为 0 的数组
	var e = [0]int{}                // 定义一个长度为 0 的数组
	var f = [...]int{}              // 定义一个长度为 0 的数组
	fmt.Println(a, b, c, d, g, e, f)

}

二、切片

2.1

Cap 成员表示切片指向的内存空间的最大容量(对应元素的个数,而不是字节数)

go 复制代码
package main

import "fmt"

func main() {
	slice()
}

// 定义 添加 删除
func slice() {
	var (
		_ []int               // nil 切片, 和 nil 相等, 一般用来表示一个不存在的切片
		_ = []int{}           // 空切片, 和 nil 不相等, 一般用来表示一个空的集合
		c = []int{1, 2, 3}    // 有 3 个元素的切片, len 和 cap 都为 3
		d = c[:2]             // 有 2 个元素的切片, len 为 2, cap 为 3
		e = c[0:2:cap(c)]     // 有 2 个元素的切片, len 为 2, cap 为 3
		_ = c[:0]             // 有 0 个元素的切片, len 为 0, cap 为 3
		_ = make([]int, 3)    // 有 3 个元素的切片, len 和 cap 都为 3
		_ = make([]int, 2, 3) // 有 2 个元素的切片, len 为 2, cap 为 3
		_ = make([]int, 0, 3) // 有 0 个元素的切片, len 为 0, cap 为 3
	)
	fmt.Println(d, e)
	//1.末尾 添加操作
	//d = append(d, 1)       //1 2 1
	//d = append(d, 1, 2, 3) //1 2 1 2 3
	//d = append(d, []int{1, 2}...) //1 2 1 2
	d = append(d, e...) // 1 2 1 2
	fmt.Println("d:", d)

	//2.在切片开头添加元素 在开头一般都会导致内存的重新分配,从切片的开头添加元素的性能一般要比从尾部追加元素的性能差很多
	//e = append([]int{1}, e...)
	e = append([]int{-1, 0}, e...)
	fmt.Println("e:", e)

	// 3.中间插入 第二个 append 创建临时切片
	var a = []int{1, 2, 3, 4, 5}
	//a = append(a[:2], append([]int{0}, a[2:]...)...)//添加一个 1 2 0 3 4 5
	//a = append(a[:2], append([]int{0, 0}, a[2:]...)...) //添加切片
	fmt.Println("a:", a)
	// copy append 组合 避免创建临时切片
	//a = append(a, 0)   // 切片扩展 1 个空间
	//copy(a[3:], a[2:]) // a[i:] 向后移动 1 个位置
	//a[2] = 0           // 设置新添加的元素
	var A = []int{0, 0, 0}
	a = append(a, A...)       //扩展三个切片
	copy(a[2+len(A):], a[2:]) //后移三个空间
	copy(a[2:], A)            //复制新添加内容
	fmt.Println("a:", a)

	//4.删除-尾部
	a = []int{1, 2, 3}
	//a = a[:len(a)-1] //1 2 删除尾部一个元素
	a = a[:len(a)-2] //1  删除尾部2个元素
	// 删除-头部 移动指针
	a = []int{1, 2, 3}
	a = a[1:] //a[N:] 删除开头 N 个元素 len(a)=2, cap(a)=2
	// 删除-头部 不移动数据指针,不会导致内存空间结构变化
	a = []int{1, 2, 3}
	a = append(a[:0], a[1:]...) //删除开头1个元素 len(a)=2, cap(a)=3  append(a[:0], a[N:]...) 删除开头N个元素
	//删除-头部 copy
	a = []int{1, 2, 3}
	//a = a[:copy(a, a[1:])] //copy(a, a[1:])=2 删除开头 1 个元素  a[N:] 删除开头N个元素 元素为: 2 3
	a = a[:copy(a, a[2:])]

	//5.删除-中间 append
	a = []int{1, 2, 3, 4, 5}
	a = append(a[:2], a[3:]...) //append(a[:i], a[i+1:]...) 删除中间 1 个元素
	a = append(a[:2], a[4:]...) // append(a[:i], a[i+N:]...) 删除中间 N 个元素
	//删除-中间 copy
	a = []int{1, 2, 3, 4, 5}
	//a = a[:copy(a[1:], a[2:])+1] //删除中间 1 个元素 a = a[:i+copy(a[i:], a[i+1:])]
	a = a[:copy(a[1:], a[3:])+1] // 删除中间 n 个元素 a = a[:i+copy(a[i:], a[i+N:])]
	fmt.Println("删除:", a)
}

三、哈希表

四、字符串

4.1 定义

go 复制代码
package main

import "fmt"

func main() {
	string()
}

func string() {
	s := "hello,world"
	/*
		1.字符串虽然不是切片,但是支持切片操作
	*/
	s1 := s[:5]             //hello
	s2 := s[6:]             //world
	s3 := "hello,world"[:5] //hello
	fmt.Println(s, s1, s2, s3, len(s3))
}
相关推荐
anlog5 分钟前
C#在自定义事件里传递数据
开发语言·c#·自定义事件
奶香臭豆腐18 分钟前
C++ —— 模板类具体化
开发语言·c++·学习
晚夜微雨问海棠呀25 分钟前
长沙景区数据分析项目实现
开发语言·python·信息可视化
graceyun26 分钟前
C语言初阶习题【9】数9的个数
c语言·开发语言
小蜗牛慢慢爬行1 小时前
如何在 Spring Boot 微服务中设置和管理多个数据库
java·数据库·spring boot·后端·微服务·架构·hibernate
波音彬要多做1 小时前
41 stack类与queue类
开发语言·数据结构·c++·学习·算法
Swift社区1 小时前
Excel 列名称转换问题 Swift 解答
开发语言·excel·swift
一道微光1 小时前
Mac的M2芯片运行lightgbm报错,其他python包可用,x86_x64架构运行
开发语言·python·macos
矛取矛求1 小时前
QT的前景与互联网岗位发展
开发语言·qt
Leventure_轩先生1 小时前
[WASAPI]从Qt MultipleMedia来看WASAPI
开发语言·qt