首页 > 其他分享 >Scala之Array数组

Scala之Array数组

时间:2024-11-20 15:43:50浏览次数:3  
标签:数组 val Scala dreamList arr1 println Array

 可修改Array

import scala.collection.mutable.ArrayBuffer
//Array:数组
//可修改的:ArrayBuffer
//不可修改的:Array
object Test1 {
  //可修改的:ArrayBuffer
  def main(args: Array[String]): Unit = {
    //1.新建
    val arr1 =ArrayBuffer(1,2,3)
    //2.添加
    arr1 +=4
    arr1.insert(0,100)
    //3.删除
    arr1-=3//删除指定元素
    arr1.remove(0)//删除指定位置(下标)的元素
    //4.修改。通过下标来修改
    arr1(0)=50//把下标为0的元素赋值为50
    //注意 下标不能越界。有效的范围是:0-长度-1
    println(arr1.length)//length 长度,用来获取元素的个数
    println(arr1(10))//IndexOutOfBoundsException
    //5.查询
    //5.1  判断某个元素在数组中是否存在
    println(s"50在数组中吗?${arr1.contains(50)}")
    //5.2找到指定的元素的下标
    //-1:表示这个元素在数组中不存在!
  println(s"500在数组中的下标是?${arr1.contains(500)}")
    //6.遍历
    //for, foreach,iterator
    //for(i<-arr1)println(i)
    //println("-"*50)
    //arr1.foreach(println)
    //println("-"*50)
    for(i<-arr1)println(i)
    println("-"*50)
    arr1.foreach(println)
    println("-"*50)
    val it1=arr1.iterator
    while (it1.hasNext)
      println(it1.next())
  }
}

 不可修改Array

  //不可变的Array:长度不可变
  def main(args: Array[String]): Unit = {
    val arr1 = Array(1, 2, 3)
    arr1(0) = 100
    arr1.foreach(println)

    //数组的常用的方法 (对于可变和不可变的数组都可以使用)
    //1.截取。从源数组中,取一部分,组成一个新的数组
    //arr1.slice(起点下标-不包括)
    val arr2=arr1.slice(2,5)
    arr2.foreach(println)
    //2.遍历.foreach
    //3.映射 map
    //Array(1,2,3)-------->Array(2,4,6)
    val arr3 =Array(1,2,3).map(_*2)
      arr3.foreach(println)//(2,4,6)
    //4.过滤filter
    println("-"*50)
    val arr4=Array(2,3,4,5,6).filter(e=>e%2==1)
    arr4.foreach(println)
    //5.折叠reduce
  println(Array(1,2,3,4).reduce((a,b)=>a+b))
  println("-"*50)

    //多维数组
    val arr5=Array(Array(1,2,3),
    Array(4,5,6),
    Array(7,8,9))
    //9
    println(  arr5(2)(2)  )
    //4
    println(  arr5(1)(0)  )
    //创造二维数据
//    val arr6=Array.ofDim[Int](3,3,3)
//    arr6(0)(0)(0)=1
    //由一维数组接化得到二维的数组
val arr6=Array(2,3,4,5,6).grouped(3)//对数组中的元素,三组一个,升级为二维数组
    while (arr6.hasNext){
      val rs =arr6.next()
      println(rs(0))
    }

run......

课后小习题

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

2.要创建-个可变 Array,需要(B)
A.使用 val 关键字和 Arrey 类型。
B.导入scala.collection.mutable.ArrayBuffer,并使用

C,直接使用 Array 类型,无需导入其他库。
D.使用 vax 关键字和 Array 类型。

3.对于-个 Array,获取其长度使用(B)

A.可以随时修改其元素的值。
B.可以欧变其大小
C.一旦创建,内容和大小都不能改变。
D.不能使用索引访问无素。
4.创建一个可变Array,要(B
A使用val关键字和Array共型。
B.等入scala. collection mutable.ArrayBuffer并使用它创建。
C.直接使用Array兴型,无善导入共他库。
D.使用war关键字和Array共型。
5.财于一个Ary。联取美长庆使用(B
A.SLze属性。
B. length 黑性
C.count方法
D.没有专门的方法或属性获取长度。
6.在多维数组中,访问无素需要(B)
A.使用一个索马。#
B.根据维度数量使用相应数量的索引。
C.不能直接访问无素。
D,使用特殊的访问方法。
7.grouped方法的作用是(B)
A.将数组无素随机打乱。
B.将数组按照指定大小分组。
C.对数纪无素进行排序。
D.计算数组无素的总和。

操作任务

梦想清单管理

case class DreamItem(content: String, isCompleted: Boolean, dueDate: String, priority: Int)

import scala.collection.mutable.ArrayBuffer

object DreamListManagement {
  def main(args: Array[String]): Unit = {
    // 创建可变的DreamItem数组
    val dreamList = ArrayBuffer[DreamItem]()

    // 添加3个梦想
    dreamList += DreamItem("稳定的工作", false, "2034-12-31", 3)
    dreamList += DreamItem("一个自己房子", false, "2035-06-30", 2)
    dreamList += DreamItem("养一只狗狗", false, "2034-11-30", 1)

    // 将第2个梦想设置为已完成
    dreamList(1) = dreamList(1).copy(isCompleted = true)

    // 调高第3个梦想的优先级,这里假设调高到5
    dreamList(2) = dreamList(2).copy(priority = 5)

    // 根据优先级从高到低排序
    val sortedDreams = dreamList.sortBy(_.priority)(Ordering.Int.reverse)

    // 把优先级排名前5的梦想保存到一个新的列表中
    val topFiveDreams = sortedDreams.take(5)

    // 循环输出梦想列表
    topFiveDreams.foreach { dream =>
      println(s"内容: ${dream.content}, 是否完成: ${dream.isCompleted}, 截止日期: ${dream.dueDate}, 优先级: ${dream.priority}")
    }
  }
}

run.....

标签:数组,val,Scala,dreamList,arr1,println,Array
From: https://blog.csdn.net/2301_82118291/article/details/143861472

相关文章

  • 0基础勇闯C语言(2) 数组
    数组可分为数值数组,字符数组,指针数组,结构体数组。一,一维数组1,一维数组的命名inta[5]={1,2,9,23,8};(数组下标范围是0-n-1)2,一维数组的应用冒泡排序和选择排序二,二维数组1,二维数组的命名(2种)inta[2][3]={{1,2,3},{4,5,6}};inta[2][3]={1,2,3,4,5,6};2,二维数组的理解......
  • 2024-11-20:交替子数组计数。用go语言,给定一个二进制数组 nums, 如果一个子数组中的相邻
    2024-11-20:交替子数组计数。用go语言,给定一个二进制数组nums,如果一个子数组中的相邻元素的值都不相同,我们称这个子数组为交替子数组。请返回数组nums中交替子数组的总数。输入:nums=[0,1,1,1]。输出:5。解释:以下子数组是交替子数组:[0]、[1]、[1]、[1]以及[0,1]。......
  • PHP二维数组排序算法函数
    以使用PHP内置的array_multisort()函数来对二维数组进行排序。array_multisort()函数可以对多个数组或多维数组的一个或多个列进行排序。下面是一个示例函数,该函数可以对二维数组按指定列进行排序:<?phpfunctionsort2DArrayByColumn(&$array,$columnKey,$sortOrder=SORT_......
  • 洛谷题单指南-二叉堆与树状数组-P2161 [SHOI2009] 会场预约
    原题链接:https://www.luogu.com.cn/problem/P2161题意解读:本题前面形式化描述已经足够清晰。解题思路:要判断线段之间是否有冲突(包含或者交叉),可以借助set,参考:https://www.cnblogs.com/jcwy/p/18447333只不过这里要统计冲突的数量,也就是允许相等的元素重复存在,可以借助multiset......
  • 3354. 使数组元素等于零
     给你一个整数数组 nums 。开始时,选择一个满足 nums[curr]==0 的起始位置 curr ,并选择一个移动 方向 :向左或者向右。此后,你需要重复下面的过程:如果 curr 超过范围 [0,n-1] ,过程结束。如果 nums[curr]==0 ,沿当前方向继续移动:如果向右移,则 递增 curr......
  • 数据结构复习 ---- 顺序表(数组)--定长版本+不定长版本
    //我的思考************////1.顺序表是一种线性结构(一对一关系),每个数据都是有一个前驱(除了第一个元素)和一个后继(除了最后一个元素)//2.顺序表分为定长顺序表(指针存储固定数量的元素)和不定长顺序表(顾名思义。。。使用较多)----类似于动态数组,就像Go语言中的切片,Pytho......
  • 超详细的ArrayList扩容过程(配合源码详解)
    首先,在调用add方法的时候,会去调用ensureCapacityInternal方法,传入一个参数minCapacity大小是size+1,也就是现在我们需要的数组的最小的大小。在ensureCapacityInternal方法中,先判断一下elementdata是不是初始空数组是的话就把minCapacity变更为默认容量也就是10,和传进......
  • 2024/11/18日 日志 数据结构实验(1)---链表逆置、线性表A,B顺序存储合并、双向循环链表应
    链表逆置题目:https://pintia.cn/problem-sets/1855808612225744896/exam/problems/type/6?problemSetProblemId=1855808768018968576解答:点击查看代码structListNode*reverse(structListNode*head){structListNode*prev=NULL;structListNode*current=head;......
  • 字节青训-小C的类二进制拼图、小M的奶酪问题、小T的密码变换规则、数值操作的期望计算
    目录一、小C的类二进制拼图问题描述测试样例解题思路:问题理解数据结构选择算法步骤第一版代码:最终代码:  二、小M的奶酪问题问题描述测试样例解题思路:问题理解数据结构选择算法步骤 最终代码:运行结果: 三、小T的密码变换规则问题描述测试样例 解题......
  • 字节青训-判断数组是否单调、判断回旋镖的存在、字符串解码问题、小F的矩阵值调整、数
    目录一、判断数组是否单调问题描述测试样例解题思路:解题思路数据结构选择算法步骤 最终代码:运行结果:​编辑  二、判断回旋镖的存在问题描述测试样例解题思路: 解题思路算法步骤最终代码:运行结果:​编辑 三、字符串解码问题问题描述测试样例 解题思......