清华尹成带你实战GO案例(47)Go 切片

article/2025/9/18 3:41:46
Go 切片
切片是Go语言的关键类型之一,它提供了比数组更多的功能。
示例1:
package main
import "fmt"
func main() {
// 和数组不同的是,切片的长度是可变的。
// 我们可以使用内置函数make来创建一个长度不为零的切片
// 这里我们创建了一个长度为3,存储字符串的切片,切片元素
// 默认为零值,对于字符串就是""。
s := make([]string, 3)
fmt.Println("emp:", s)
// 可以使用和数组一样的方法来设置元素值或获取元素值
s[0] = "a"
s[1] = "b"
s[2] = "c"
fmt.Println("set:", s)
fmt.Println("get:", s[2])
// 可以用内置函数len获取切片的长度
fmt.Println("len:", len(s))
// 切片还拥有一些数组所没有的功能。
// 例如我们可以使用内置函数append给切片追加值,然后
// 返回一个拥有新切片元素的切片。
// 注意append函数不会改变原切片,而是生成了一个新切片,
// 我们需要用原来的切片来接收这个新切片
s = append(s, "d")
s = append(s, "e", "f")
fmt.Println("apd:", s)
// 另外我们还可以从一个切片拷贝元素到另一个切片
// 下面的例子就是创建了一个和切片s长度相同的新切片
// 然后使用内置的copy函数来拷贝s的元素到c中。
c := make([]string, len(s))
copy(c, s)
fmt.Println("cpy:", c)
// 切片还支持一个取切片的操作 "slice[low:high]"
// 获取的新切片包含元素"slice[low]",但是不包含"slice[high]"
// 下面的例子就是取一个新切片,元素包括"s[2]","s[3]","s[4]"。
l := s[2:5]
fmt.Println("sl1:", l)
// 如果省略low,默认从0开始,不包括"slice[high]"元素
l = s[:5]
fmt.Println("sl2:", l)
// 如果省略high,默认为len(slice),包括"slice[low]"元素
l = s[2:]
fmt.Println("sl3:", l)
// 我们可以同时声明和初始化一个切片
t := []string{"g", "h", "i"}
fmt.Println("dcl:", t)
// 我们也可以创建多维切片,和数组不同的是,切片元素的长度也是可变的。
twoD := make([][]int, 3)
for i := 0; i < 3; i++ {
innerLen := i + 1
twoD[i] = make([]int, innerLen)
for j := 0; j < innerLen; j++ {
twoD[i][j] = i + j
}
}
fmt.Println("2d: ", twoD)
}


输出结果为
emp: [ ]
set: [a b c]
get: c
len: 3
apd: [a b c d e f]
cpy: [a b c d e f]
sl1: [c d e]
sl2: [a b c d e]
sl3: [c d e f]
dcl: [g h i]
2d: [[0] [1 2] [2 3 4]]
数组和切片的定义方式的区别在于 [] 之中是否有 固定长度 或者推断长度标志符 ... 。
示例2:

package main
import "fmt"
func main() {
s1 := make([]int, 0)
test(s1)
fmt.Println(s1)
}
func test(s []int) {
s = append(s, 3)
//因为原来分配的空间不够,所以在另外一个地址又重新分配了空间,所以原始地址的数据没有变
}


输出结果为:
[]
若改为:
package main
import "fmt"
func main() {
s1 := make([]int, 0)
s1 = test(s1)
fmt.Println(s1)
}
func test(s []int) []int {
s = append(s, 3)
return s
}


输出结果为:
[3]//正确结果
示例3:
cap是slice的最大容量,append函数添加元素,如果超过原始slice的容量,会重新分配底层数组。

package main
import "fmt"
func main() {
s1 := make([]int, 3, 6)
fmt.Println("s1= ", s1, len(s1), cap(s1))
s2 := append(s1, 1, 2, 3)
fmt.Println("s1= ", s1, len(s1), cap(s1))
fmt.Println("s2= ", s2, len(s2), cap(s2))
s3 := append(s2, 4, 5, 6)
fmt.Println("s1= ", s1, len(s1), cap(s1))
fmt.Println("s2= ", s2, len(s2), cap(s2))
fmt.Println("s3= ", s3, len(s3), cap(s3))
}


输出结果为:
s1= [0 0 0] 3 6
s1= [0 0 0] 3 6
s2= [0 0 0 1 2 3] 6 6
s1= [0 0 0] 3 6
s2= [0 0 0 1 2 3] 6 6
s3= [0 0 0 1 2 3 4 5 6] 9 12
示例4:
指向同一底层数组的slice之间copy时,允许存在重叠。copy数组时,受限于src和dst数组的长度最小值。
package main
import "fmt"
func main() {
s1 := []int{0, 1, 2, 3, 4, 5, 6, 7, 8, 9}
s2 := make([]int, 3, 20)
var n int
n = copy(s2, s1)
fmt.Println(n, s2, len(s2), cap(s2))
s3 := s1[4:6]
fmt.Println(n, s3, len(s3), cap(s3))
n = copy(s3, s1[1:5])
fmt.Println(n, s3, len(s3), cap(s3))
}


输出结果:

3 [0 1 2] 3 20
3 [4 5] 2 6

2 [1 2] 2 6





网址:http://www.qukuailianxueyuan.io/



欲领取造币技术与全套虚拟机资料

区块链技术交流QQ群:756146052  备注:CSDN

尹成学院微信:备注:CSDN



网址:http://www.qukuailianxueyuan.io/



欲领取造币技术与全套虚拟机资料

区块链技术交流QQ群:756146052  备注:CSDN

尹成学院微信:备注:CSDN


http://chatgpt.dhexx.cn/article/xQu4Gg0D.shtml

相关文章

视频教程-清华-尹成老师-Python爬虫day34-Python

清华-尹成老师-Python爬虫day34 毕业于清华大学&#xff0c;曾担任Google算法工程师&#xff0c;微软人工智能领域全球最具价值专家&#xff0c;微软Tech Ed 大会金牌讲师。 精通C/ C&#xff0c;Python ,Go语言,Sicikit-Learn与TensorFlow拥有15年编程经验与5年的教学经验&…

视频教程-尹成老师带你学算法-Java

尹成老师带你学算法 毕业于清华大学&#xff0c;曾担任Google算法工程师&#xff0c;微软区块链领域全球最具价值专家&#xff0c;微软Tech Ed 大会金牌讲师。 精通C/ C&#xff0c;Python ,Go语言,Sicikit-Learn与TensorFlow拥有15年编程经验与5年的教学经验&#xff0c;资深软…

区块链最全线下培训大纲——尹成学院

区块链乃大势所趋&#xff0c;尹成学院联合微软加清华名师打造最强教学团队。传播智慧我们用心&#xff0c;人生冲锋你们用力 第一阶段&#xff1a;区块链及其行业及Golang编程 第一周- Go语言快速入门&#xff1a; &#xff08;a&#xff09;了解区块链从业人员的薪资结构组…

视频教程-清华-尹成老师-Python爬虫day14-Python

清华-尹成老师-Python爬虫day14 毕业于清华大学&#xff0c;曾担任Google算法工程师&#xff0c;微软人工智能领域全球最具价值专家&#xff0c;微软Tech Ed 大会金牌讲师。 精通C/ C&#xff0c;Python ,Go语言,Sicikit-Learn与TensorFlow拥有15年编程经验与5年的教学经验&…

尹成c语言开发环境工具,清华学神尹成带你实战Rust编程(1)

原标题&#xff1a;清华学神尹成带你实战Rust编程(1) Rust 语言是一种高效、可靠的通用高级语言。其高效不仅限于开发效率&#xff0c;它的执行效率也是令人称赞的&#xff0c;是一种少有的兼顾开发效率和执行效率的语言。 Rust 语言由 Mozilla 开发&#xff0c;最早发布于 201…

清华大学尹成 怎么样

清华大学尹成 怎么样 编程能力极强&#xff0c;算法能力极强&#xff0c;业界的最强算法王者 清华学神尹成的数据结构与算法,全程golang代码实战 ------------------------------------------------------------- 1 时间效率分析 ---------------------------------------…

清华尹成人工智能tensorflow(2)-尹成-专题视频课程

清华尹成人工智能tensorflow&#xff08;2&#xff09;—527人已学习 课程介绍 清华尹成人工智能tensorflow&#xff08;2&#xff09;资料联系客服&#xff1a;475318423 课程收益 清华尹成人工智能tensorflow&#xff08;2&#xff09; 讲师介绍 尹成 更多讲师课程 尹成…

伯努利分布、二项分布

一、伯努利分布&#xff08;又称为0-1分布、两点分布&#xff09; 伯努利试验说的是下面一种事件情况&#xff1a;在生活中&#xff0c;有一些事件的发生只有两种可能&#xff0c;发生或者不发生&#xff08;或者叫成功或者失败&#xff09;&#xff0c;这些事件都可以被称为伯…

matplotlib绘制伯努利分布的概率密度图

根据伯努利分布的定义&#xff0c;我们可以得到以下公式&#xff1a; f ( x ) p x ( 1 − p ) 1 − x for x ∈ { 0 , 1 } f(x)p^{x}(1-p)^{1-x} \quad \text { for } x \in\{0,1\} f(x)px(1−p)1−x for x∈{0,1}当我们进行观测&#xff0c;得到了事件 x x x发生频率的观测值…

伯努利分布,二项分布,多项分布

师兄给我说&#xff0c;做机器学习的方法有两种&#xff1a;一种是修改公式的那种&#xff0c;另外一种是类比。我觉得我适合的应该就是类比的这种&#xff0c;公式太难了。。 伯努利分布 记住这种分布的话&#xff0c;就开始想抛硬币&#xff0c;只抛一次硬币。正面朝上的概…

伯努利分布,二项分布和泊松分布以及最大似然之间的关系(未完成)

首先说伯努利试验 伯努利分布 伯努利试验说的是下面一种事件情况&#xff1a;在生活中&#xff0c;有一些事件的发生只有两种可能&#xff0c;发生或者不发生&#xff08;或者叫成功或者失败&#xff09;&#xff0c;这些事件都可以被称为伯努利试验。 伯努利试验的概率分布称…

多元伯努利分布 multivariate bernoulli distribution

今天看论文发现了一个名次&#xff0c;多元伯努利分布&#xff0c;百度好久也没查到明确的定义&#xff0c;去google了一下&#xff0c;发现其实就是 基本概统里的一次伯努利试验推广到多次试验后的结果分布&#xff0c;如下图&#xff1a; 引用来源&#xff1a; https://www…

MATLAB生成伯努利图分布,C++ - 随机生成器 伯努利分布(bernoulli distribution) 的 详解 及 代码...

随机生成器 伯努利分布(bernoulli distribution) 的 详解 及 代码 本文地址: http://blog.csdn.net/caroline_wendy/article/details/17335871 伯努利分布(bernoulli distribution), 是判断某件事情发生或者未发生的概率; 给定参数p, 可以修改概率的值, 发生概率(true)是p,未发…

基于python/scipy学习概率统计(2):伯努利分布(Bernoulli Distribution)

目录 1. 概念 2. 概率分布 2.1 概率质量函数 2.2 概率分布函数 2.3 生存函数&#xff0c;风险函数 2.4 百分点函数 3. 常用统计特征 3.1 均值&#xff0c;Mean 3.2 中位数&#xff0c;Median 3.3 众数&#xff0c;Mode 3.4 方差&#xff0c;Variance 3.5 偏度&#…

matlab伯努利分布,常用的概率分布:伯努利分布、二项式分布、多项式分布、先验概率,后验概率...

一&#xff0c;伯努利分布(bernouli distribution) 又叫做0-1分布&#xff0c;指一次随机试验&#xff0c;结果只有两种。也就是一个随机变量的取值只有0和1。记为: 0-1分布 或B(1,p)&#xff0c;其中 p 表示一次伯努利实验中结果为正或为1的概率。 概率计算&#xff1a; P(X0)…

伯努利分布(一种离散分布)

伯努利分布&#xff08;0-1分布&#xff09; 笔记来源&#xff1a;Introduction to the Bernoulli Distribution 伯努利分布&#xff08;1次试验&#xff09;是二项分布&#xff08;n次试验&#xff09;的特例&#xff0c;其中进行了一次实验&#xff08; n 1 n1 n1&#xff…

伯努利分布(Bernoulli distribution)

伯努利分布 是一种离散分布,有两种可能的结果。1表示成功&#xff0c;出现的概率为p(其中0<p<1)。0表示失败&#xff0c;出现的概率为q1-p。这种分布在人工智能里很有用&#xff0c;比如你问机器今天某飞机是否起飞了&#xff0c;它的回复就是Yes或No&#xff0c;非常明确…

伯努利分布、二项分布、多项分布、Beta分布、Dirichlet分布

https://blog.csdn.net/michael_r_chang/article/details/39188321 https://www.cnblogs.com/wybang/p/3206719.html https://blog.csdn.net/jteng/article/details/60334628 1. 伯努利分布 伯努利分布(Bernoulli distribution)又名两点分布或0-1分布&#xff0c;介绍伯努利分…

【愚公系列】2022年09月 微信小程序-自定义tabBar的实现

文章目录 前言一、自定义tabBar的实现1.全局配置2.主页面3.CustomTabBar组件4.效果 前言 小程序自带的tabBar可以参考这篇文章&#xff1a;https://codeboy.blog.csdn.net/article/details/123040278 因为小程序自带的tabBar&#xff0c;比较单一&#xff0c;无法满足多样化需…

[cryptoverse ctf 2022] cvctf

一直在等wp&#xff0c;一直没找着&#xff0c;没有wp就没有进步。 把已知部分写出来吧&#xff0c;抛砖引玉 这个比赛只有crypto,reverse和misc(除一个签到外&#xff0c;都推特油管和谷歌网盘的题作不了) 目录 crypto Warmup 3 Warmup 1 Warmup 2 Substitution RSA 1…