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}")
    }
  }
}
相关推荐
广州腾科助你拿下华为认证2 小时前
华为考试:HCIE数通考试难度分析
大数据·华为
在未来等你4 小时前
Elasticsearch面试精讲 Day 17:查询性能调优实践
大数据·分布式·elasticsearch·搜索引擎·面试
大数据CLUB7 小时前
基于spark的澳洲光伏发电站选址预测
大数据·hadoop·分布式·数据分析·spark·数据开发
ratbag6720138 小时前
当环保遇上大数据:生态环境大数据技术专业的课程侧重哪些领域?
大数据
计算机编程小央姐9 小时前
跟上大数据时代步伐:食物营养数据可视化分析系统技术前沿解析
大数据·hadoop·信息可视化·spark·django·课程设计·食物
智数研析社10 小时前
9120 部 TMDb 高分电影数据集 | 7 列全维度指标 (评分 / 热度 / 剧情)+API 权威源 | 电影趋势分析 / 推荐系统 / NLP 建模用
大数据·人工智能·python·深度学习·数据分析·数据集·数据清洗
潘达斯奈基~10 小时前
《大数据之路1》笔记2:数据模型
大数据·笔记
寻星探路11 小时前
数据库造神计划第六天---增删改查(CRUD)(2)
java·大数据·数据库
翰林小院12 小时前
【大数据专栏】流式处理框架-Apache Fink
大数据·flink
孟意昶13 小时前
Spark专题-第一部分:Spark 核心概述(2)-Spark 应用核心组件剖析
大数据·spark·big data