打开APP
userphoto
未登录

开通VIP,畅享免费电子书等14项超值服

开通VIP
大数据学习路线分享Scala系列之数组

1. 定长数组

创建一个定长数组的方式

使用Array定义一个长度不变的数组

object ArrayDemo {

def main(args: Array[String]){

//初始化一个长度为8的定长数组,其所有元素均为0

val arr1 = new Array[Int](8)

//直接打印定长数组,内容为数组的hashcode值

println(arr1)

//将数组转换成数组缓冲,就可以看到原数组中的内容了

//toBuffer会将数组转换长数组缓冲

println(arr1.toBuffer)

//注意:如果不使用new获取数组,相当于调用了数组的apply方法,直接为数组赋值

//初始化一个长度为1,值为10的定长数组

val arr2 = Array[Int](10)

//输出数组元素值

println(arr2.toBuffer)

//定义一个长度为3的定长数组

val arr3 = Array("hadoop", "storm", "spark")

//使用()来访问元素

println(arr3(2))

//包含10个整数的数组,初始化值为0

val nums = new Array[Int](10)

//遍历数组

for(i <- 0 until nums.length)

print(s"$i:${nums(i)} ")

println()

//包含10个字符串的数组,初始化值为null

val strs0 = new Array[String](10)

for(i <- 0 until strs0.length)

print(s"$i:${strs0(i)} ")

println()

//赋初值的字符串数组

val strs1 = Array("hello" ,"world")

for(i <- 0 until strs1.length)

print(s"$i:${strs1(i)} ")

println()

//访问并修改元素值

strs1(0) = "byebye"

for(i <- 0 until strs1.length)

print(s"$i:${strs1(i)} ")

println()

}

}

result

2. 变长数组

定义变长数组的方式:

使用 ArrayBuffer定义长度按需变化的数组。

import scala.collection.mutable.ArrayBuffer

object VarArrayDemo {

def main(args: Array[String]){

//定义一个空的可变长Int型数组

val nums = ArrayBuffer[Int]()

//在尾端添加元素

nums += 1

//在尾端添加多个元素

nums += (2,3,4,5)

//使用++=在尾端添加任何集合

nums ++= Array(6,7,8)

//这些操作符,有相应的 -= ,--=可以做数组的删减,用法同+=,++=

//使用append追加一个或者多个元素

nums.append(1)

nums.append(2,3)

//在下标2之前插入元素

nums.insert(2,20)

nums.insert(2,30,30)

//移除最后2元素

nums.trimEnd(2)

//移除最开始的一个或者多个元素

nums.trimStart(1)

//从下标2出移除一个或者多个元素

nums.remove(2)

nums.remove(2,2)

//使用增强for循环进行数组遍历

for(elem <- nums)

println(elem)

//基于下标访问使用增强for循环进行数组遍历

for(i <- 0 until nums.length)

println(nums(i))

}

}

执行结果:

3. 遍历数组

1.增强for循环,参见变长数组的代码

2.好用的until会生成脚标,0 until 10 包含0不包含10 参见定长数组部分代码4.1.4. 数组转换

4. 数组转换

yield关键字将原始的数组进行转换会产生一个新的数组,原始的数组不变

bject ArrayTransfer {

def main(args: Array[String]): Unit = {

//使用for推导式生成一个新的数组

val a = Array(1, 2, 3, 4, 5, 6, 7, 8, 9)

val res1 = for(elem <- a) yield 2*elem

for(elem <- res1)

print(elem+" ")

println()

//对原数组元素过滤后生成一个新的数组

//将偶数取出乘以10后再生成一个新的数组

val res2 = for(elem <- a if elem%2 == 0)yield 2*elem

for(elem <- res2)

print(elem+" ")

println()

//使用filter和map转换出新的数组

val res3 = a.filter(_ % 2 == 0).map(2 * _)

for(elem <- res3)

print(elem+" ")

println()

}

执行结果:

5. 数组常用算法

在Scala中,数组上的某些方法对数组进行相应的操作非常方便!

object ArrayAlgorithm { def main(args: Array[String]): Unit = { val a = Array(9, 1, 2, 5, 3, 7, 8, 4) //求和 val res1 = a.sum println(res1) //求最大值 val res2 = a.max println(res2) //排序 val res3 = a.sorted // val res4 = a.sortWith(_>_)指定排序方式 for(elem <- res3) print(elem + " ")  }}

执行结果:

本站仅提供存储服务,所有内容均由用户发布,如发现有害或侵权内容,请点击举报
打开APP,阅读全文并永久保存 查看更多类似文章
猜你喜欢
类似文章
【热】打开小程序,算一算2024你的财运
scala
3000门徒内部训练绝密视频(泄密版)第1课:大数据最火爆语言Scala光速入门
Scala Data Structure
Scala入门教程
大数据开发-Scala-类型检查与模式匹配详解
多维数组与Json格式的转化
更多类似文章 >>
生活服务
热点新闻
分享 收藏 导长图 关注 下载文章
绑定账号成功
后续可登录账号畅享VIP特权!
如果VIP功能使用有故障,
可点击这里联系客服!

联系客服