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}")

}

}

}

相关推荐
爱编程的王小美3 天前
Scala 入门指南
开发语言·后端·scala
旋风小飞棍4 天前
spark和hadoop的区别与联系
大数据·开发语言·scala
搞程序的心海8 天前
Flink 编程基础:Scala 版 DataStream API 入门
大数据·flink·scala
不要天天开心8 天前
Spark-SQL与Hive的连接及数据处理全解析
spark·scala
胡萝卜糊了Ohh9 天前
spark-sql
spark·scala
搞程序的心海10 天前
Flink DataStream API深度解析(Scala版):窗口计算、水位线与状态编程
大数据·flink·scala
WiKiLeaks_successor11 天前
Scala day4(tuple, set and map)
scala
胡萝卜糊了Ohh11 天前
scala
开发语言·后端·scala
QX_hao11 天前
【spark--scala】--环境配置
大数据·spark·scala