【原创】go语言学习(七)数组
目录
- 数组定义
- 二维数组
- 数组拷贝、传参
数组定义
1. 数组是同一类型的元素集合。
var a [3]int
//定义一个数组 //Go中数组下标从0开始,因此⻓长度为n的数组下标范围:[0,n-1] //整数组中的元素默认初始化为0,字符串串数组中的元素默认初始化为””
2. 数组初始化
var a [3]int
a[0] = 10
a[1] = 20
a[2] = 30
//数组初始化 var a [3]int = [3]int{10, 20, 30}
//定义时数组初始化 a := [3]int{10, 20, 30}
//定义时数组初始化 a := […]int{10, 20, 30}
//定义时数组初始化 a := [3]int{10}
//定义时数组初始化 a := [3]int{2:10}
//定义时数组初始化
3. 数组⻓长度是类型的一部分
var a [3]int
a[0] = 10
a[1] = 20
a[2] = 30
var b [5]int
b = a
//a、b是不同类型的数组,不能赋值
4、len内置函数
var a [3]int
a[0] = 10
a[1] = 20
a[2] = 30
fmt.Printf(“len:%d\n”, len(a))
//a、b是不同类型的数组,不能赋值
5. 数组遍历
var a [3]int
a[0] = 10
a[1] = 20
a[2] = 30
for i := 0; i < len(a); i++ {
}
//a、b是不同类型的数组,不能赋值
var a [3]int
a[0] = 10
a[1] = 20
a[2] = 30
for index, val := range a {
}
//a、b是不不同类型的数组,不不能赋值
二维数组
1、 二维数组
var a [3][2]int
a[0][0] = 10
a[0][1] = 20
a[1][0] = 30
a[1][1] = 30
a[2][0] = 30
a[2][1] = 30
for index, val := range a {
}
//a、b是不不同类型的数组,不不能赋值
2、二维数组(二)
// 数组遍历写法二
func testArra10() {
// 数组 a [长度]类型
// 定义完成, 值为[0,0,0,100,300],指定特定下标
a := [5]int{3: 100, 4: 300}
for index, value := range a {
fmt.Printf("a[%d]=%d\n", index, value)
}
}
3、二维数组(三)
// 二维数组定义
func testArra11() {
var a [3][2]int
a[0][0] = 10
a[0][1] = 20
a[1][0] = 30
a[1][1] = 40
a[2][0] = 50
a[2][1] = 60 fmt.Println(a) // 遍历二维数组
for i := 0; i < 3; i++ {
for j := 0; j < 2; j++ {
fmt.Printf("%d", a[i][j])
}
fmt.Println()
} //遍历方式二
fmt.Println("other method")
for i, val := range a {
// %v自动匹配格式输出,行
fmt.Printf("row[%d]=%v\n", i, val)
for j, val2 := range val {
fmt.Printf("(%d,%d)=%d", i, j, val2)
}
} }
数组拷贝、传参
1、数组是值类型
var a [3]int
a[0] = 10
a[1] = 20
a[2] = 30
b := a
//b拷贝了了数组a中所有元素
b[0] = 1000
fmt.Println(a, b)
2、 数组是值类型,函数传参也会拷贝
// 值类型,copy为全拷贝,改变b不会影响a
func testArra12() {
a := [3]int{10, 20, 30}
b := a
b[0] = 1000
fmt.Printf("a=%v\n", a)
fmt.Printf("b=%v\n", b)
} // int类型都是值类型,copy为全拷贝,改变b不会影响a
func testArray13() {
var a int = 1000
b := a
b = 3000
fmt.Printf("a=%d b=%d\n", a, b)
} // 数组传参为copy
func modify(b [3]int) {
b[0] = 1000
}
例子:
package main import (
"fmt"
"math/rand"
"time"
) func sumArray(a [10]int) int {
var sum int = 0
//第一种遍历
for i := 0; i < len(a); i++ {
sum = sum + a[i]
} //第二种遍历, _ 屏蔽下标
//for _, val := range a{
// sum = sum + val
//} return sum
} // 随机10数相加
func testArraySum() { //初始化随机种子,time.Now().Unix()纳秒时间
rand.Seed(time.Now().Unix()) var b [10]int
for i := 0; i < len(b); i++ {
//b[i] = i
//随机 rand
// 产生一个0到999的随机数
b[i] = rand.Intn(1000)
// 产生一个0到Int最大值的随机数
// b[i] = rand.Int()
} sum := sumArray(b)
fmt.Printf("sum=%d\n", sum)
} // 两个元素之和,等于8 target的下标
func TwoSum(a [5]int, target int) {
for i := 0; i < len(a); i++ {
other := target - a[i]
for j := i + 1; j < len(a); j++ {
if a[j] == other {
fmt.Printf("(%d, %d)\n", i, j)
}
}
}
} //
func testTwoSum() {
// var b [5]int = [5]int{1,3,5,8,7}
// b := [5]int{1,3,5,8,7}
b := [...]int{1, 3, 5, 8, 7}
TwoSum(b, 8)
} func main() {
//sumArray()
//testArraySum()
testTwoSum()
}
【原创】go语言学习(七)数组的更多相关文章
- C语言学习004:数组与指针
在C语言中,字符串实际上就是字符数组,在内存中字符串"Shatner"存储的形式是这样的
- C语言学习笔记--数组指针和指针数组
C 语言中的数组有自己特定的类型,数组的类型由元素类型和数组大小共同决定.(如 int array[5]类型为 int[5]) 1.定义数组类型 C 语言中通过 typedef 为数组类型重命名:ty ...
- go语言学习--指针数组和数组指针
数组指针(也称行指针)定义 int (*p)[n];()优先级高,首先说明p是一个指针,指向一个整型的一维数组,这个一维数组的长度是n,也可以说是p的步长.也就是说执行p+1时,p要跨过n个整型数据的 ...
- go语言学习(一):数组/切片
学习区块链之后,发现还要学习加密,接触到的视频是:Go的crypto包,所以开始接触Go.因为和solidity有些相似,但是比solidity简单一些,就开始放松的心态去学习.每天翻着go菜鸟教程, ...
- C语言学习笔记--数组参数和指针参数
1. 数组参数退化为指针的意义 (1)C 语言中只会以值拷贝的方式传递参数,当向函数传递数组时,将整个数组拷贝一份传入函数导致执行效率低下,C 语言以高效作是最初的设计目标,所以这种方法是不可取的. ...
- c语言学习笔记 —— 数组
1. 数组的内存分配原理. 数组定义 int a[3] = {1,3,11}; 如下写法是错误的: int number; int a[number] = {1,7,9}; 原因是:没有定长的数组初 ...
- c语言学习笔记.数组.
数组: 可以存储一个固定大小的相同类型元素的顺序集合,比如int类型的数组.float类型的数组,里面存放的数据称为“元素”. 所有的数组都是由连续的内存位置组成.最低的地址对应第一个元素,最高的地址 ...
- GO 语言学习笔记--数组切片篇
1.对于make 数组切片,长度和容量需要理解清楚: 容量表示底层数组的大小,长度是你可以使用的大小: 容量的用处在哪?在与当你用 appen d扩展长度时,如果新的长度小于容量,不会更换底层数组,否 ...
- Dart语言学习(七)Dart Map类型
映射(Maps)是无序的键值对: 常用属性: keys 获取所有的key值 values 获取所有的value值 isEmpty 是否为空 isNotEmpty 是否不为空 常用方法: remove( ...
随机推荐
- Git config 使用说明(转)
原文:https://blog.csdn.net/gdutxiaoxu/article/details/79253737
- java 任务定时调度(定时器)
任务定时调度 通过Timer和Timetask,我们可以实现定时启动某个线程. java.util.Timer 在这种实现方式中,Timer类作用是类似闹钟的功能,也就是定时或者每隔一定时间触发一次线 ...
- Effective Java 读书笔记(一):创建和销毁对象
1 构造器 => 静态工厂方法 (1)优势 静态工厂方法有名字 静态工厂方法不必在每次被调用时都产生一个新的对象 静态工厂方法能返回原返回类型的任意子类型的对象 静态工厂方法根据调用时传入的不同 ...
- iOS - starckView 类似Android线性布局
同iOS以往每个迭代一样,iOS 9带来了很多新特性.UIKit框架每个版本都在改变,而在iOS 9比较特别的是UIStackView,它将从根本上改变开发者在iOS上创建用户界面的方式.本文将带你学 ...
- STM8 工程模版
在st官网下载STM8固件库 拷贝固件库到工程目录下 再创建两个目录 user:存放用户文件.自己编写的源文件 project:存放工程文件 拷贝stm8s_conf.h到user目录下 AIR 创建 ...
- linux sort命令用法
sort命令:用于将文本文件内容加以排序,sort可针对文本文件的内容,以行为单位来排序. 命令格式: sort [-bcdfimMnr][-o<输出文件>][-t<分隔字符> ...
- 一个让Java事半功倍的反射库
在Java和Android中,我们常常会使用反射来达到一些兼容的目的.Java原生提供的反射很是麻烦,使用起来很是不方便.比如我们想要调UserManager的静态方法get,使用原生的实现如下 tr ...
- C# - 配置动态更新
生产中经常会遇到修改配置的情况,但是又需要重启应用程序,是不是有点小烦躁.... 下面了解下在不重启情况下,实现配置更新实时生效 public static void SetConfig(string ...
- [dev][ipsec][distributed] strongswan如何做热迁移/高可用/High Availability
问题描述: 原生的基于kernel 的 strongswan 如何做高可用,HA,High Availability 问题分析: 基于我们已知的,ipsec,strongswan的知识.问题分解如下: ...
- Python_while语句
1.while语句: count = 0 while (count<4): count +=1 print('准备放入第'+str(count)+'个杯子') 注:还是要注意一下,条件之后加“: ...