Scala学习记录,Array

server/2024/11/24 19:30:34/

数组:物理空间上连续的(一个挨一个)优势:根据下标能快速找到元素。

列表:物理空间上不连续(不是一个元素挨着一个元素的)优势:插入元素,删除较快。

Array定义:数组:物理空间上连续的(一个挨着一个)

格式:数组名(下标)

可变不可变:

默认为不可变数组

查看数组的元素。根据下标:格式 数组名(下标)
下标从0开始
如果超过最大的下标,会报错:.ArrayIndexOutOfBoundsException

遍历用:for , foreach , iterator

可变可对元素进行添加,删除等操作;不可变创建后元素不能修改

如果要定义可变的Array,需要额外导入包:import scala.collection.mutable.ArrayBuffer

小习一下:

1.下面关于不可变数组说法正确的是?( B )
A. 可以随时修改其元素的值。
B. 可以改变其大小。
C.一旦创建,内容和大小都不能改变。
D.不能使用索引访间元素。

2.要创建一个可变 Array, 需要( B )
A. 使用 val 关键字和 Array 类型。
B. 导入 scala. collection. mutable.ArrayBuffer 并使用他创建
C. 直接使用 Array 类型,无需导入其他库
D.使用 var 关键字和 Array 类型。


3.对于一个 Array,获取其长度使用( B )
A. size 属性。
B. length 属性。
C. count 方法
D. 没有专门的方法或属性获取长度。


4. 在多维数组中,访间元素需要( B )

A.使用一个索引。
B. 根据维度数量使用相应数量的索引。
C. 不能直接访问元素
D. 使用待殊的询问方法。

4.grouped方法的作用是( B )

A. 将数组元素随机打乱。

B .将数组按照指定大小分组。

C .对数组元案进行排序。

D .计算数组元素的总和。

实训训练:

任务背景:梦想清单管理。
1. 使用 case class 定义DreamItem类。它的属性有:内容,是否完成,截止日期,优先级。
2.定义可变Array 来保存DreamItem。
3.添加3个梦想
4.将第2个梦想设置为已完成。
5.调高第3个梦想的优先级
6.根据优先级进行从高到低排序
7.把优先级排名前5的梦想保存到一个新的列表中
8.循环输出梦想列表

// 1. 使用case class定义DreamItem类
case class DreamItem(content: String, isCompleted: Boolean, dueDate: String, priority: Int)object DreamListManagement {def main(args: Array[String]) {// 2. 定义可变Array来保存DreamItemimport scala.collection.mutable.ArrayBufferval dreamList = ArrayBuffer[DreamItem]()// 3. 添加3个梦想dreamList += DreamItem("去旅行", false, "2025-12-31", 3)dreamList += DreamItem("学习一门新语言", false, "2026-06-30", 2)dreamList += DreamItem("完成一个重要项目", false, "2024-12-31", 1)// 4. 将第2个梦想设置为已完成dreamList(1) = dreamList(1).copy(isCompleted = true)// 5. 调高第3个梦想的优先级dreamList(2) = dreamList(2).copy(priority = 4)// 6. 根据优先级进行从高到低排序val sortedDreamList = dreamList.sortBy(_.priority)(Ordering.Int.reverse)// 7. 把优先级排名前5的梦想保存到一个新的列表中val top5Dreams = sortedDreamList.take(5)// 8. 循环输出梦想列表println("梦想列表:")top5Dreams.foreach(dream => println(s"内容: ${dream.content}, 是否完成: ${dream.isCompleted}, 截止日期: ${dream.dueDate}, 优先级: ${dream.priority}"))}
}


http://www.ppmy.cn/server/144622.html

相关文章

大数据面试题每日练习--HDFS是如何工作的?

HDFS(Hadoop Distributed File System)是一个分布式文件系统,设计用于存储非常大的文件。它的主要工作原理如下: NameNode:管理文件系统的命名空间,维护文件目录树和文件元数据信息。NameNode记录每个文件…

一学就废|Python基础碎片,列表(List)

列表(数组)是一种常见的数据结构,通常,列表的共性操作包括获取、设置、搜索、过滤和排序。以下是对列表的一些常用的操作方法。 基本操作 我们可以在 Python 中操作列表的方法有很多。在我们开始学习这些通用操作之前,以下片段显示了列表最常…

[OpenHarmony5.0][Docker][环境]OpenHarmony5.0 Docker编译环境镜像下载以及使用方式

0. 制作过程 如果你想知道这个镜像是如何制作的,请看下面的教程,如果你只想拿到镜像。那就往下看就好了 链接: 1. 获取源码 源码下载请参考:OHOS_5.0中的[源码下载]章节,建议使用镜像站点下载。 2. 获取镜像 在Git…

【STM32】MPU6050初始化常用寄存器说明及示例代码

一、MPU6050常用配置寄存器 1、电源管理寄存器1( PWR_MGMT_1 ) 此寄存器允许用户配置电源模式和时钟源。 DEVICE_RESET :用于控制复位的比特位。设置为1时复位 MPU6050,内部寄存器恢复为默认值,复位结束…

鸿蒙操作系统(HarmonyOS)开发的初学者了解和入门

1. 什么是鸿蒙操作系统(HarmonyOS) 鸿蒙操作系统是华为开发的一种分布式操作系统,面向多种设备(如智能手机、智能家居设备、穿戴设备、车机等)。它的特点包括: 分布式架构:支持跨设备无缝协作…

ArcGIS计算水库库容量

一、数据获取 DEM数据来源于地理空间数据云,该网站是由中科院计算机网络信息中心于2008年创立的地学大数据平台。 二、填洼 将DEM数据中凹陷的区域填充至与倾斜点同样高度,这里的【Z限制】说的是设定一个特定的值,凹陷区域的最低点高程与倾斜…

【大数据学习 | Spark-Core】Spark的改变分区的算子

当分区由多变少时,不需要shuffle,也就是父RDD与子RDD之间是窄依赖。 当分区由少变多时,是需要shuffle的。 但极端情况下(1000个分区变成1个分区),这时如果将shuffle设置为false,父子RDD是窄依赖关系&…

springboot开发环境搭建 maven,mybatis plus

Maven 配置 项目构建工具maven的安装与配置 maven 的意思是专家 创建目录如下 /maven /maven 存放安装程序/mavenProject 存放maven项目/repository 存放本地仓库的jar包 配置\apache-maven-3.6.3\conf\settings.xml 在<settings>里面标签修改以下内容 添加 &l…