11.17 Scala练习:梦想清单管理

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

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

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

  3. 添加3个梦想

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

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

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

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

  8. 循环输出梦想列表

Scala 复制代码
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}")
    }
  }
}
相关推荐
海南java第二人10 小时前
Flink 核心概念深度解析:从字符串大小写转换看 Job 与 Task 的本质区别
大数据·flink
橘子编程10 小时前
Flink从入门到精通:全面实战指南
大数据·flink
SeaTunnel10 小时前
深度解析 Apache SeaTunnel 核心引擎三大技术创新:高可靠异步持久化与 CDC 架构优化实战
大数据·数据库·架构·apache·seatunnel
DolphinScheduler社区11 小时前
第 8 篇|Apache DolphinScheduler 与 Flink Spark 数据引擎的边界、协同与最佳实践
大数据·flink·spark·开源·apache·海豚调度·大数据工作流调度
黄焖鸡能干四碗11 小时前
企业元数据梳理和元数据管理方案(PPT方案)
大数据·运维·网络·分布式·spark
木心术111 小时前
大数据处理技术:Hadoop与Spark核心原理解析
大数据·hadoop·分布式·spark
BizViewStudio17 小时前
甄选 2026:AI 重构新媒体代运营行业的三大核心变革与落地路径
大数据·人工智能·新媒体运营·媒体
Cx330❀19 小时前
Linux命名管道(FIFO)通信:从原理到实操,一文搞懂跨进程通信
大数据·linux·运维·服务器·elasticsearch·搜索引擎
汽车仪器仪表相关领域19 小时前
NHVOC-70系列固定污染源挥发性有机物监测系统:精准破局工业VOCs监测痛点,赋能环保合规升级
大数据·人工智能·安全性测试
实证小助手21 小时前
世界各国经济政策不确定指数(1997-2024年)月度数据
大数据·人工智能