Scala数组,定长数组和变长数组,增强for循环,until用法,数组转换,数组常用算法,数组其它操作

2024-04-19 18:32

本文主要是介绍Scala数组,定长数组和变长数组,增强for循环,until用法,数组转换,数组常用算法,数组其它操作,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1. 数组

1.1. 定长数组和变长数组

package cn.toto.scala//可变数组的长度时需要引入这个包
import scala.collection.mutable.ArrayBuffer/*** Created by toto on 2017/6/27.*/
object ArrayDemo {def main(args: Array[String]): Unit = {//初始化一个长度为8的定长数组,其所有元素均为0val arr1 = new Array[Int](8)//直接打印定长数组,内容为数组的的hashcode值println(arr1)//将数组转换成数组缓冲,就可以看到原数组中的内容了。//toBuffer会将数组转换成数组缓冲println(arr1.toBuffer)//注意:如果没有new,相当于调用了数组的apply方法,直接为数组赋值//赋初始一个长度为1的定长数组val arr2 = Array[Int](10)println(arr2.toBuffer)//定义一个长度为3的定长数组var arr3 = Array("hadoop","storm","spark")//使用()来访问元素println(arr3(2))//////////////////////////////////////////////////////////////////变长数组(数组缓冲)//如果想使用数组缓冲,需要导入import scala.collection.mutable.ArrayBuffer包val ab = ArrayBuffer[Int]()//向数组缓冲的尾部追加一个元素//+=尾部追加元素ab += 1println(ab)//追加多个元素ab += (2,3,4,5)println(ab)//追加一个数组++=ab ++= Array(6,7)println(ab)//追加一个数组缓冲ab ++= ArrayBuffer(8,9)//打印数组缓冲abprintln(ab)//在数组某个位置插入元素用inseret,其中第一个参数是其实位置,后面两个参数是要添加进入的值ab.insert(0,-1,0)println(ab)//删除数组某个位置的元素用remove,下面的含义是从0这个位置开始,删除2个元素ab.remove(0,2)println(ab)}
}

运行后的结果如下:

[I@4563e9ab
ArrayBuffer(0, 0, 0, 0, 0, 0, 0, 0)
ArrayBuffer(10)
spark
ArrayBuffer(1)
ArrayBuffer(1, 2, 3, 4, 5)
ArrayBuffer(1, 2, 3, 4, 5, 6, 7)
ArrayBuffer(1, 2, 3, 4, 5, 6, 7, 8, 9)
ArrayBuffer(-1, 0, 1, 2, 3, 4, 5, 6, 7, 8, 9)
ArrayBuffer(1, 2, 3, 4, 5, 6, 7, 8, 9)

1.2. 遍历数组

1.增强for循环
2.好用的until会生成脚标,0 until 10 包含0不包含10
这里写图片描述

package cn.toto.scala/*** Created by toto on 2017/6/28.*/
object ForArrayDemo {def main(args: Array[String]): Unit = {//初始化一个数组val arr = Array(1,2,3,4,4,5,6,7,8)//增强for循环for(i <- arr)print(i + " ")println("")//好用的until会生成一个Range//reverse是将前面生成的Range反转for(i <- (0 until arr.length).reverse)print(arr(i) + " ")}
}

运行后的结果如下:

1 2 3 4 4 5 6 7 8 
8 7 6 5 4 4 3 2 1

1.3. 数组转换

yield关键字将原始的数组进行转换会产生一个新的数组,原始的数组不变
这里写图片描述

package cn.toto.scala/*** Created by toto on 2017/6/28.*/
object ArrayYieldDemo {def main(args: Array[String]): Unit = {//定义一个数组val arr = Array(1,2,3,4,5,6,7,8,9)//将偶数取出乘以10后再生成一个新的数组val res = for(e <- arr if e % 2 == 1) yield e * 10println(res.toBuffer)//更高级的写法,用着更爽//filter是过滤,接收一个返回值为boolean的函数//map相当于将数组中的每一个元素取出来,应用传进去的函数val r = arr.filter(_ % 2 == 0).map(_ * 10)println(r.toBuffer)}
}

运行后的结果如下:

ArrayBuffer(10, 30, 50, 70, 90)
ArrayBuffer(20, 40, 60, 80)

1.4. 数组常用算法

在Scala中,数组上的某些方法对数组进行相应的操作非常方便!
这里写图片描述
其它数组操作:

scala> var arr = Array(1,6,5,4,7,9,2,25,22,11)
arr: Array[Int] = Array(1, 6, 5, 4, 7, 9, 2, 25, 22, 11)升序排序
scala> arr.sorted
res13: Array[Int] = Array(1, 2, 4, 5, 6, 7, 9, 11, 22, 25)降序
scala> arr.sorted.reverse
res14: Array[Int] = Array(25, 22, 11, 9, 7, 6, 5, 4, 2, 1)scala> arr.sortWith(_>_)
res15: Array[Int] = Array(25, 22, 11, 9, 7, 6, 5, 4, 2, 1)上面的等价下面的,相当于是降序:
scala> arr.sortWith((x,y) => x > y)
res16: Array[Int] = Array(25, 22, 11, 9, 7, 6, 5, 4, 2, 1)下面是升序
scala> arr.sortWith((x,y) => x < y)
res17: Array[Int] = Array(1, 2, 4, 5, 6, 7, 9, 11, 22, 25)scala> val a = Array("hadoop",1.0,2)
a: Array[Any] = Array(hadoop, 1.0, 2)scala> a(1).asInstanceOf[Double]
res20: Double = 1.0scala> val arr1 = new Array[Int](8)
arr1: Array[Int] = Array(0, 0, 0, 0, 0, 0, 0, 0)scala> arr1(1) = 6scala> arr1
res26: Array[Int] = Array(0, 6, 0, 0, 0, 0, 0, 0)定义变长数组,需要引入包:
scala> import scala.collection.mutable.ArrayBuffer
import scala.collection.mutable.ArrayBufferscala> val ab = new ArrayBuffer[Int]()
ab: scala.collection.mutable.ArrayBuffer[Int] = ArrayBuffer()scala> ab += 1
res27: ab.type = ArrayBuffer(1)scala> ab
res28: scala.collection.mutable.ArrayBuffer[Int] = ArrayBuffer(1)scala> ab += 2
res30: ab.type = ArrayBuffer(1, 2)scala> ab += (2,3,4,5)
res31: ab.type = ArrayBuffer(1, 2, 2, 3, 4, 5)scala>

这篇关于Scala数组,定长数组和变长数组,增强for循环,until用法,数组转换,数组常用算法,数组其它操作的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/918271

相关文章

Java导入、导出excel用法步骤保姆级教程(附封装好的工具类)

《Java导入、导出excel用法步骤保姆级教程(附封装好的工具类)》:本文主要介绍Java导入、导出excel的相关资料,讲解了使用Java和ApachePOI库将数据导出为Excel文件,包括... 目录前言一、引入Apache POI依赖二、用法&步骤2.1 创建Excel的元素2.3 样式和字体2.

Java实现将Markdown转换为纯文本

《Java实现将Markdown转换为纯文本》这篇文章主要为大家详细介绍了两种在Java中实现Markdown转纯文本的主流方法,文中的示例代码讲解详细,大家可以根据需求选择适合的方案... 目录方法一:使用正则表达式(轻量级方案)方法二:使用 Flexmark-Java 库(专业方案)1. 添加依赖(Ma

使用EasyExcel实现简单的Excel表格解析操作

《使用EasyExcel实现简单的Excel表格解析操作》:本文主要介绍如何使用EasyExcel完成简单的表格解析操作,同时实现了大量数据情况下数据的分次批量入库,并记录每条数据入库的状态,感兴... 目录前言固定模板及表数据格式的解析实现Excel模板内容对应的实体类实现AnalysisEventLis

kotlin中的行为组件及高级用法

《kotlin中的行为组件及高级用法》Jetpack中的四大行为组件:WorkManager、DataBinding、Coroutines和Lifecycle,分别解决了后台任务调度、数据驱动UI、异... 目录WorkManager工作原理最佳实践Data Binding工作原理进阶技巧Coroutine

MyBatis-Plus中Service接口的lambdaUpdate用法及实例分析

《MyBatis-Plus中Service接口的lambdaUpdate用法及实例分析》本文将详细讲解MyBatis-Plus中的lambdaUpdate用法,并提供丰富的案例来帮助读者更好地理解和应... 目录深入探索MyBATis-Plus中Service接口的lambdaUpdate用法及示例案例背景

MyBatis-Plus中静态工具Db的多种用法及实例分析

《MyBatis-Plus中静态工具Db的多种用法及实例分析》本文将详细讲解MyBatis-Plus中静态工具Db的各种用法,并结合具体案例进行演示和说明,具有很好的参考价值,希望对大家有所帮助,如有... 目录MyBATis-Plus中静态工具Db的多种用法及实例案例背景使用静态工具Db进行数据库操作插入

Java实现将byte[]转换为File对象

《Java实现将byte[]转换为File对象》这篇文章将通过一个简单的例子为大家演示Java如何实现byte[]转换为File对象,并将其上传到外部服务器,感兴趣的小伙伴可以跟随小编一起学习一下... 目录前言1. 问题背景2. 环境准备3. 实现步骤3.1 从 URL 获取图片字节数据3.2 将字节数组

Windows命令之tasklist命令用法详解(Windows查看进程)

《Windows命令之tasklist命令用法详解(Windows查看进程)》tasklist命令显示本地计算机或远程计算机上当前正在运行的进程列表,命令结合筛选器一起使用,可以按照我们的需求进行过滤... 目录命令帮助1、基本使用2、执行原理2.1、tasklist命令无法使用3、筛选器3.1、根据PID

SpringBoot操作MaxComputer方式(保姆级教程)

《SpringBoot操作MaxComputer方式(保姆级教程)》:本文主要介绍SpringBoot操作MaxComputer方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的... 目录引言uqNqjoe一、引入依赖二、配置文件 application.properties(信息用自己

如何通过Golang的container/list实现LRU缓存算法

《如何通过Golang的container/list实现LRU缓存算法》文章介绍了Go语言中container/list包实现的双向链表,并探讨了如何使用链表实现LRU缓存,LRU缓存通过维护一个双向... 目录力扣:146. LRU 缓存主要结构 List 和 Element常用方法1. 初始化链表2.