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集合操作实战 --------------------------------------------------------------- ...
随机推荐
- 猴子选大王【PHP】
目录 猴子选大王 指针解决 数组压栈 猴子选大王 一群猴子排成一圈,按1,2,...,n依次编号.然后从第1只开始数,数到第m只,把它踢出圈,从它后面再开始数,再数到第m只,在把它踢出去...,如此不 ...
- SpringBoot 中解决跨域请求
CORS 理解 同源策略是web浏览器实现的一个重要的安全概念,它防止JavaScript代码对不同的来源(例如,不同的域)发出请求,而不是它所服务的来源.虽然同源策略有效地防止来自不同来源的资源,但 ...
- 对1001. A+B Format (20)的描述
Github仓库的链接 https://github.com/deepYY/object-oriented/blob/master/A-B-Format/A.B.Format.c 解题思路: 输入a, ...
- apache、nginx实现反向代理
一.apache(不推荐): 代理80端口:a. 配置:b. 效果:c. 配置文件参考: ServerRoot "/etc/httpd" Listen 80 ProxyPass / ...
- Selenium & Webdriver 远程测试和多线程并发测试
Selenium & Webdriver 远程测试和多线程并发测试 Selenium Webdriver自动化测试,初学者可以使用selenium ide录制脚本,然后生成java程序导入ec ...
- flink Window的Timestamps/Watermarks和allowedLateness的区别
Watermartks是通过additional的时间戳来控制窗口激活的时间,allowedLateness来控制窗口的销毁时间. 注: 因为此特性包括官方文档在1.3-1.5版本均未做改变,所以 ...
- Android小游戏应用---撕破美女衣服游戏
ImageView after; ImageView before; @Override protected void onCreate(Bundle savedInstanceState) { su ...
- Linux Shell常用技巧(九)
十九. 和系统运行进程相关的Shell命令: 1. 进程监控命令(ps): 要对进程进行监测和控制,首先必须要了解当前进程的情况,也就是需要查看当前进程,而ps命令就是最基本同时 ...
- Android 把url生成二维码并贴到给定的底图上
主要是用到了com.google.zxing jar包生成二维码的功能,这个jar包需要自己接下载 直接上代码 public static Bitmap CreateBinaryCodeImageBy ...
- Win 10安装11g 客户端条件检查失败,INS-30131 无法从节点 "desktop-njm3a7m" 检索 exectask 的版本
Win 10安装11g 客户端条件检查失败,[INS-30131] 执行安装程序验证所需的初始设置失败.无法从节点 "desktop-njm3a7m" 检索 exectask 的版 ...