Scala数组操作
数组操作
- 初始化固定长度的数组
// 初始化长度为10的数组
val array = new Array[Int](10)
// 初始化创建含有hello与Scala的数组
val s = Array("hello","scala")
- 创建可变的数组(类似java的集合)
Scala中创建长度可变的数组,类似与java中的ArrayList一样Scala提供了ArrayBuffer,下面是ArrayBuffer的用法:
// 创建集合等同于下面的new ArrayBuffer[Int]()
val b = ArrayBuffer[Int]()
new ArrayBuffer[Int]()
// 集合添加元素类似与java中的list.add()多次调用添加函数
b += (1, 2, 3, 4, 5, 6)
// 可以追加新的集合元素类似java中的list.addAll()
b ++=Array(7,8,9,10)
// 移除前//5个元素
b.trimStart(5)
/**
* 数组尾部删除或者添加元素是非常快,但是中间 * 插入元素或者移除元素,操作较慢
*/
val c = new ArrayBuffer[Int]()
c+=(1,2,3)
// 在索引2处插入元素6
c.insert(2,6)// ArrayBuffer(1, 2, 6, 3)
// 删除索引为2元素
c.remove(2)
// 删除索引1后一个元素
c.remove(1,1)
有时候创建元素,不知道存储多少元素可以创建数组缓存ArrayBuffer,然后调用toArray方法将缓冲区间转为Array(类似于java中StringBuffer.toString方法)
- 遍历数组和数组缓冲
val a = ArrayBuffer[Int]()
a+=(1,2,3,4,5,6)
//遍历数组(变量i取值从0到a.length-1)
for(i<- 0 until a.length) println(a(i))
println(a(i)
// 遍历偶数下标索引元素
for(i<- 0 until (a.length,2)) println(a(i))
// 倒着遍历索引
for(i<- (0 until a.length).reverse) println(a(i))
// yield元素填充
val result =for (e <- list) yield e *2
// 数组转换
val list = Array(1, 2, 3, 4)
// yield元素填充
val result = for (e <- list) yield e * 2
println(result.toBuffer)
// 舍弃偶数元素
val res = for (e <- list if e % 2 == 0) yield e
println(res.toBuffer)
// 也可以使用函数式编程使用filter和Map
val req = a.filter(_ % 2 == 0).map(2 * _)
}
- Scala的常用算法
Scala中有计算求和和排序
val list = Array(1, 2, 3, 4)
// 求和,求数组最大值,排序,而排序并不会影响原有的数组
println(list.sum, list.max,list.sorted.toBuffer)
| 方法 | 方法描述 |
|---|---|
| def append(elems:A*):Unit | 方法接受多个类型为A的元素,例如b.append(1,2)将对b追加2个元素 |
| def count(p:(A)=>Boolean):Int | 方法接受一个布尔值表达式,例如a.count(_>0)将会统计多个正数 |
方法demo
val list = Array(8, 5, 1, 2, 3, 4)
val bs = list.sorted.toBuffer
bs.append(1,2)
println(bs)
// 统计集合大于4的元素个数
println( bs.count(_ > 4))
Scala数组操作的更多相关文章
- Scala 数组操作之Array、ArrayBuffer以及遍历数组
ArrayBuffer 在Scala中,如果需要类似于Java中的ArrayList这种长度可变的集合类,则可以使用ArrayBuffer. // 如果不想每次都使用全限定名,则可以预先导入Array ...
- Scala数组操作实战详解
增删改查,要注意的是,Array数组是定长数组,ArrayBuffer数组才是变长数组. 其他集合也存在可变不可变.例如,List,Set,Map 多维数组定义方法与Java类似.
- Scala 数组操作之数组转换
使用yield和函数式编程转换数组 // 对Array进行转换,获取的还是Array val a = Array(1, 2, 3, 4, 5) val a2 = for (ele <- a) y ...
- Scala编程入门---数组操作之Array.ArrayBuffer以及遍历数组
在Scala中,Array代表的含义与Java类似,也是长度不可改变的数组.此外,由于Scala与java都是运行在JVM中,双方可以互相调用,因此Scala数组底层实际上是java数组.列如字符串数 ...
- [转] Scala 的集合类型与数组操作
[From] https://blog.csdn.net/gongxifacai_believe/article/details/81916659 版权声明:本文为博主原创文章,转载请注明出处. ht ...
- Scala数组| 集合
arrays :+ 5尾部 头部5 +: arrays TODO 声明不可变数组,不能删; 默认情况下,scala中集合的声明全都是不可变的 val arrays: Array[Int] = Ar ...
- Spark记录-Scala数组
Scala提供了一种数据结构叫作数组,数组是一种存储了相同类型元素的固定大小顺序集合.数组用于存储数据集合,但将数组视为相同类型变量的集合通常更为有用. 可以声明一个数组变量,例如:numbers,使 ...
- Scala数组和集合
一.scala数组 数组定义1: var arr = new Array[String](3) String:存储的元素类型 3:存储3个元素 添加元素: arr(1) = "hello&q ...
- Scala实战高手****第6课 :零基础实战Scala集合操作及Spark源码解析
本课内容1.Spark中Scala集合操作鉴赏2.Scala集合操作实战 --------------------------------------------------------------- ...
随机推荐
- Python实例---抽屉热搜榜前端代码分析
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...
- python 脚本运行时报错: AttributeError: 'module' object has no attribute ***
最近在编写Python脚本过程中遇到一个问题比较奇怪:Python脚本完全正常没问题,但执行总报错"AttributeError: 'module' object has no attrib ...
- python_机器学习—sklearn_win_64-3.6安装&&测试
下载网址:http://www.lfd.uci.edu/~gohlke/pythonlibs/ 在之前numpy\scipy基础上,安装sklearn_win_64-3.6 pip install D ...
- c++计算器后续(3)
自娱自乐: 本来只是想改改第二次的代码规范的,然后好像把原来的代码玩坏了,真是尴尬...然后大概是又发现了一些东西.以上. main的参数: 大概是说main函数的括号里是可以带参数的,写成这个样子: ...
- mvvm模型
- 使用jenkins SonarQube gitlab 构建自动化发布系统
目前持续集成的生态越来越完善,工具也有很多,开源的或商业的.如: 最最流行的,也是使用最多的 Jenkins 有着持续集成DNA的ThoughtWorks GO.理念:"Deployment ...
- TP,TN,FP,FN
一张图搞定~~~ [转]https://blog.csdn.net/u011956147/article/details/78967145
- [USACO11JAN]Roads and Planes
嘟嘟嘟 这道题他会卡spfa,不过据说加SLF优化后能过,但还是讲讲正解吧. 题中有很关键的一句,就是无向边都是正的,只有单向边可能会有负的.当把整个图缩点后,有向边只会连接在每一个联通块之间(因为图 ...
- 随手练——HDU 1284 动态规划入门
#include <iostream> #include <algorithm> #include <string.h> using namespace std; ...
- Azure Blob数据迁移工具
数据迁移备份,更多的应用场景见https://docs.azure.cn/zh-cn/storage/common/storage-moving-data?toc=%2fstorage%2fblobs ...