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

}

}

}

相关推荐
渣渣盟2 天前
Flink事件时间与窗口操作实战指南
大数据·flink·scala
深兰科技6 天前
深兰科技与淡水河谷合作推进:矿区示范加速落地
java·人工智能·python·c#·scala·symfony·深兰科技
渣渣盟9 天前
Flink流处理:温度跳变检测与状态管理
大数据·flink·scala
小冯不疯15 天前
金蝶云星空与轻易云集成平台数据对接方案
全文检索·scala
howard200517 天前
1.6.2 掌握Scala数据结构 - 列表
scala·不可变列表·可变列表
howard200522 天前
1.6.1 掌握Scala数据结构 - 数组
scala·定长数组·变长数组
渣渣盟24 天前
Flink Table API与SQL流数据处理实战
大数据·sql·flink·scala
howard20051 个月前
1.5 掌握Scala内建控制结构
scala·内建控制结构
howard20051 个月前
1.1.2 Windows上安装Scala
scala·windows版本
allway21 个月前
Debian Regular Expressions
运维·debian·scala