【大数据处理学习笔记】1.6 掌握Scala数据结构

本文详细介绍了Scala中数组的定义、遍历和常用方法,包括静态与动态初始化、数组遍历(正向、反向)、求和、最大值和最小值等操作。同时,讲解了变长数组ArrayBuffer的使用,包括添加、删除、合并和排序。此外,还探讨了列表(不可变与可变)的创建、添加元素、合并和排序。最后提到了映射、元组和集合的相关概念和操作。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1、数组定义
(1)定义数组时初始化数据
数组的静态初始化

自动推断数组类型


手动指定数据类型

(2)定义时指定数组长度,后赋值
先定义,后赋值,这叫数组的动态初始化


避免数组下标越界错误(数据溢出:Data Overflow)

 

 


2、数组遍历
定义数组arr(自动推断类型,静态初始化)

可以使用for循环对数组进行遍历,输出数组所有的元素
(1)传统for循环方式
通过数组下标来遍历数组元素


大家可以看到,反向遍历没有输出结果,怎么解决这个问题?

参考一下Java正向和反向遍历数组,看能否得到启发


通过arr.length - 1 to 0 by -1实现反向遍历


说明:num1 to num2 by 1 相当于 num1 to num2

(2)增强for循环方式
正序遍历数组元素

反序遍历数组元素

(3)利用foreach算子遍历数组
联想Java里列表的forEach()方法结合Lambda表达式

利用Scala的foreach算子来遍历数组

课堂练习:数组求和
采用遍历算子

采用增强for循环

课堂练习:采用传统for循环来求和

3、常用方法
Scala对数组提供了很多常用的方法,使用起来非常方便
定义数组arr(通过数组类的构造方法来初始化数组,静态初始化)

对数组arr也可以采用先定义后赋值的方式(动态初始化)

(1)求数组中数值总和
调用sum方法

其实,还可以调用归并算子来求和

(2)求数组中的最大值
调用max方法,也可以自己编写代码求最大值

(3)求数组中的最小值
调用min方法,也可以自己编写代码求最小值

(4)对数组实现升序
调用sorted方法

不可变数组调用sorted方法之后会产生一个新的排序数组,而原来的数组保持不变
联想一下SQL语句如何实现表记录的排序:SELECT * FROM t_student WHERE gender = '男' ORDER BY age ASC;
(5)对数组实现降序
先调用sorted方法升序,再调用reverse方法反序,就可以实现数组降序

联想一下SQL语句如何实现表记录的排序:SELECT * FROM t_student WHERE gender = '男' ORDER BY age DESC;
试一试,Python列表如何实现升序和降序

Python列表的sort()方法是直接在原列表上进行排序

Python的内置函数sorted()不会改动原列表,会产生一个排序的新列表
课堂练习:数组查询
定义一个整型数组,输入一个整数,判断该整数是否在数组里,如果在数组里,给出其位置,否则提示用户该整数不在数组里。

在net.huawei.day03包里创建Exercise01对象


利用数组的contains方法判

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值