Scala梦想清单

任务背景: 梦想清单管理。

  1. 使用 case class 定义DreamItem类。它的属性有: 内容, 是否完成, 截止日期, 优先级。

  2. 定义可变 Array 来保存DreamItem。

  3. 添加3个梦想

  4. 将第2个梦想设置为已完成。

  5. 调高第3个梦想的优先级

  6. 根据优先级进行从高到低排序

  7. 把优先级排名前5的梦想保存到一个新的列表中

  8. 循环输出梦想列表

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, "2024-12-31", 3)

dreamList += DreamItem("去旅行一次", false, "2025-06-30", 2)

dreamList += DreamItem("读完10本书", false, "2024-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}")

}

}

}

相关推荐
渣渣盟5 小时前
基于Scala实现Flink的三种基本时间窗口操作
开发语言·flink·scala
zhojiew5 小时前
关于akka官方quickstart示例程序(scala)的记录
后端·scala
小伍_Five3 天前
Spark实战能力测评模拟题精析【模拟考】
java·大数据·spark·scala·intellij-idea
黄雪超3 天前
DataStreamAPI实践原理——快速上手(实操详细版)
大数据·flink·scala
白总Server5 天前
C++语法架构解说
java·网络·c++·网络协议·架构·golang·scala
vortex56 天前
Perl One-liner 数据处理——基础语法篇【匠心】
开发语言·scala·perl
老兵发新帖7 天前
Coursier:安装sbt
scala
请你喝好果汁64111 天前
indel_snp_ssr_primer
大数据·开发语言·scala
MZWeiei13 天前
Spark 中,map和foreach的区别
大数据·分布式·spark·scala
MZWeiei15 天前
区分:union(),coalesce () 和 repartition ()
大数据·分布式·spark·scala