go 数组
数组的定义和 初始化
数组是同一类型的元素集合
var a []int
//定义⼀个数组
Go中数组下标从0开始,因此长度为n的数组下标范围:[0,n-1]
整数数组中的元素默认初始化为0,字符串数组中的元素默认初始化为" "
数组初始化
var a []int
a[] =
a[] =
a[] =
//数组初始化
var a []int = []int{, , }
//定义时数组初始化
a := []int{, , }
//定义时数组初始化
a := […]int{, , }
//定义时数组初始化
a := []int{}
//定义时数组初始化
a := []int{:}
//定义时数组初始化
package main
import "fmt"
// 数组初始化
func test1() {
var a []int
a[] =
a[] =
a[] =
fmt.Println(a) // [1 2 3 0 0]
}
func test2() {
var a []int = []int{, , , , }
fmt.Println(a) // [1 2 3 4 5]
}
func test3() {
a := []int{, , , , }
fmt.Println(a) // [1 2 3 4 5]
}
func test4() {
a := [...]int{, , , , }
fmt.Println(a) // [1 2 3 4 5]
}
func test5() {
a := []int{}
fmt.Println(a) //[5 0 0]
}
func test6(){
a := []int{:, :}
fmt.Println(a) //[0 0 20 30 0]
}
func main() {
// test1()
// test2()
// test3()
// test4()
// test5()
test6()
}
数组的长度是类型的一部分
var a []int
a[] =
a[] =
a[] =
var b []int
b = a // 报错 a、b是不同类型的数组,不能赋值
package main
import "fmt"
func test1() {
// var a [3]int;
// b := [4]int{1,2,3,4}
// a = b 报错 不是 同类型的数组 不能直接 赋值
var c []int
d := []int{, , , }
c = d
fmt.Printf("c=%v\n", c)
fmt.Printf("d=%v\n", d)
}
/*
c=[1 2 3 4]
d=[1 2 3 4]
*/
func main() {
test1()
}
数组的遍历
方式一
var a []int
a[] =
a[] =
a[] =
for i := ; i < len(a); i++ { }
方式二
var a []int
a[] =
a[] =
a[] =
for index, val := range a {
}
举例
package main
import "fmt"
func test1() {
a := []int{, , , , }
for i := ; i < len(a); i++ {
fmt.Printf("a[%d]=%d\n", i, a[i])
}
}
func test2(){
a := []int{, , , , }
for index, val := range a {
fmt.Printf("a[%d]=%d\n", index, val)
}
}
/*
a[0]=1
a[1]=2
a[2]=3
a[3]=4
a[4]=5
*/
func main() {
// test1()
test2()
}
二维数组
package main
import "fmt"
func test1() {
var a [][]int
a[][] =
a[][] =
a[][] =
a[][] =
a[][] =
a[][] =
fmt.Println(a) // [[1 2] [3 4] [5 6]]
}
func test2() {
var a [][]int = [][]int{{, }, {, }, {, }}
for i := ; i < len(a); i++ {
for j := ; j < len(a[i]); j++ {
fmt.Printf("a[%d][%d] = %d\n", i, j, a[i][j])
}
fmt.Printf("\n")
}
}
func test3(){
var a [][]int = [][]int{{, }, {, }, {, }}
for index, val := range(a){
for i,v:= range(val){
fmt.Printf("a[%d][%d] = %d\n", index, i ,v)
}
fmt.Printf("\n")
}
}
func main() {
// test1()
// test2()
test3()
}
package main import (
"fmt"
)
func printarray(a [][]string) {
for _, v1 := range a {
for _, v2 := range v1 {
fmt.Printf("%s ", v2)
}
fmt.Printf("\n")
}
}
func main() {
a := [][]string{
{"lion", "tiger"},
{"cat", "dog"},
{"pigeon", "peacock"},
}
printarray(a)
var b [][]string
b[][] = "apple"
b[][] = "samsung"
b[][] = "microsoft"
b[][] = "google"
b[][] = "AT&T"
b[][] = "T-Mobile"
fmt.Printf("\n")
printarray(b)
}
数组拷贝和传参
数组是值类型
var a []int
a[] =
a[] =
a[] =
b := a
//b了数组a中所有元素
b[] =
fmt.Println(a, b)
a [10,20,30]
b [1000,20,30]
数组是值类型,函数传参也会拷贝
func main() {
var a []int
a[] =
a[] =
a[] =
modify(a)
fmt.Println(a)
}
func modify(b []int) {
b[] =
return
}
a [10,20,30]
b [1000,20,30]
练习
求数组所有元素之和
package main import (
"fmt"
"math/rand"
"time"
) func test1(a []int) int {
var sum int
// for i := 0; i < len(a); i++ {
// sum += a[i]
// } for _, v := range a {
sum += v
}
return sum
} func run() int {
rand.Seed(time.Now().Unix()) // 不设置 这个的话 rand.Intn() 取到的数据 都是 一样的
var a []int
for i := ; i < len(a); i++ {
a[i] = rand.Intn() // rand.Intn(n) 随机取出 0 - n-1 的整数
// a[i] = rand.Int() // rand.Intn() 随机取出 0- int最大范围之间的 的整数
} sum := test1(a)
return sum
} func main() {
sum := run()
fmt.Println(sum)
}
package main
import "fmt"
// 找出数组中和为给定值的两个元素的下标,例如数组:[1,3,5,8,7],找出两个元素之和等于8的下标分别是(0, 4)和(1,2)
func sumTwo(a []int, target int) {
for i := ; i < len(a); i++ {
b := target - a[i]
for j := i + ; j < len(a); j++ {
if b == a[j] {
fmt.Printf("(%d, %d)\n", i, j)
}
}
}
}
func main() {
var a []int = []int{, , , , }
sumTwo(a, )
}
go 数组的更多相关文章
- javascript中的Array对象 —— 数组的合并、转换、迭代、排序、堆栈
Array 是javascript中经常用到的数据类型.javascript 的数组其他语言中数组的最大的区别是其每个数组项都可以保存任何类型的数据.本文主要讨论javascript中数组的声明.转换 ...
- 探究javascript对象和数组的异同,及函数变量缓存技巧
javascript中最经典也最受非议的一句话就是:javascript中一切皆是对象.这篇重点要提到的,就是任何jser都不陌生的Object和Array. 有段时间曾经很诧异,到底两种数据类型用来 ...
- 编写高质量代码:改善Java程序的151个建议(第5章:数组和集合___建议75~78)
建议75:集合中的元素必须做到compareTo和equals同步 实现了Comparable接口的元素就可以排序,compareTo方法是Comparable接口要求必须实现的,它与equals方法 ...
- 了解PHP中的Array数组和foreach
1. 了解数组 PHP 中的数组实际上是一个有序映射.映射是一种把 values 关联到 keys 的类型.详细的解释可参见:PHP.net中的Array数组 . 2.例子:一般的数组 这里,我 ...
- JavaScript权威指南 - 数组
JavaScript数组是一种特殊类型的对象. JavaScript数组元素可以为任意类型,最大容纳232-1个元素. JavaScript数组是动态的,有新元素添加时,自动更新length属性. J ...
- JavaScript常见的五种数组去重的方式
▓▓▓▓▓▓ 大致介绍 JavaScript的数组去重问题在许多面试中都会遇到,现在做个总结 先来建立一个数组 var arr = [1,2,3,3,2,'我','我',34,'我的',NaN,NaN ...
- js:给定两个数组,如何判断他们的相对应下标的元素类型是一样的
题目: 给Array对象原型上添加一个sameStructureAs方法,该方法接收一个任意类型的参数,要求返回当前数组与传入参数数组(假定是)相对应下标的元素类型是否一致. 假设已经写好了Array ...
- javascript数组查重方法总结
文章参考地址:http://blog.csdn.net/chengxuyuan20100425/article/details/8497277 题目 对下列数组去重: var arr = ['aa', ...
- 掌握javascript中的最基础数据结构-----数组
这是一篇<数据结构与算法javascript描述>的读书笔记.主要梳理了关于数组的知识.部分内容及源码来自原作. 书中第一章介绍了如何配置javascript运行环境:javascript ...
- 小兔JS教程(四)-- 彻底攻略JS数组
在开始本章之前,先给出上一节的答案,参考答案地址: http://www.xiaotublog.com/demo.html?path=homework/03/index2 1.JS数组的三大特性 在J ...
随机推荐
- 【bzoj5166】[HAOI2014]遥感监测 贪心
题目描述 给出平面上 $n$ 个圆,在x轴上选出尽可能少的点,使得每个圆中至少有一个点.求这个最小点数. 输入 第1行: N R 分别表示激光点的个数和射电望远镜能检测到的半径 第2~N+1行: Xi ...
- Huge Mods UVA - 10692(指数循环节)
题意: 输入正整数a1,a2,a3..an和模m,求a1^a2^...^an mod m 解析: #include <iostream> #include <cstdio> # ...
- Linux内核分析期中知识点总结
Linux内核分析期中知识点总结 1. 计算机是如何工作的 存储程序计算机工作模型:冯诺依曼体系结构 X86汇编基础 会变一个简单的C程序分析其汇编指令执行过程 2. 操作系统是如何工作的 函数调用堆 ...
- 解题:USACO13NOV Empty Stalls
题面 当然可以用并查集做,不过你需要按秩合并+路径压缩(才可能过),因为数据范围十分不友好...... USACO的官方做法更为优秀.首先题目告诉我们牛们加入的前后顺序不影响结果(自己证明也很容易,显 ...
- 团体程序设计天梯赛 L1-049. 天梯赛座位分配(测试数据+不同方法)
Data: /*33 2 1#11 4 7 10 13 16 19 22 25 2831 33 35 37 39 41 43 45 47 4951 53 55 57 59 61 63 65 67 69 ...
- bzoj1874 [BeiJing2009 WinterCamp]取石子游戏
1874: [BeiJing2009 WinterCamp]取石子游戏 Time Limit: 5 Sec Memory Limit: 162 MBSubmit: 925 Solved: 381[ ...
- laravel 中的 toSql 获取带参数的 sql 语句
默认情况下,toSql 获取到的 sql 里面的参数使用 "?" 代替的,如下: DB::table('user')->where('id', 1)->toSql(); ...
- R语言 神经网络算法
人工神经网络(ANN),简称神经网络,是一种模仿生物神经网络的结构和功能的数学模型或计算模型.神经网络由大量的人工神经元联结进行计算.大多数情况下人工神经网络能在外界信息的基础上改变内部结构,是一种自 ...
- qsort和sort
sort()函数是C++中的排序函数其头文件为:#include<algorithm>头文件: qsort()是C中的排序函数,其头文件为:#include<stdlib.h> ...
- C++ 注册表编程
原文 C++ 注册表编程 1.基础知识 注册表的组织方式跟文件目录比较相似,主要分为根键.子键和键值项三部分,与文件目录对应的话就是根目录.子目录和文件.分别介绍一下这三部分: (1)根键.分为5个, ...