Scala的case class习题

Scala 复制代码
import scala.collection.mutable.ListBuffer
case class Book(id:String,bookName:String,author:String,price:Double,var amount:Int)

object p4 {
  def main(args: Array[String]): Unit = {
    //2
    val BookList = ListBuffer[Book]()

    //3
    BookList += Book("001", "b1", "a1", 23, 42)
    BookList += Book("002", "b2", "a2", 55, 77)
    BookList += Book("003", "b3", "a3", 82, 11)
    println(BookList)

    //4
    val book1 =Book("004", "b4", "a4", 30, 24)
//如果已经包含这本书,直接去修改数量
    val rs=BookList.find(_.id==book1.id)
    if(rs.isEmpty){
      println("没有")
      BookList+=book1
    }else{
      println("有")
      val s=rs.get//拿出具体的数据
      s.amount+=book1.amount//数量增加
    }

    //5
    var bookName="b4"
    val rs1=BookList.find(_.bookName==bookName)
    if(rs1.isEmpty)
      println(s"《$bookName》不存在")
    else
      println(s"《$bookName》存在")

    //6
    bookName = "b1"
    val rs2 = BookList.find(_.bookName == bookName)
    if (rs2.isEmpty)
      println(s"《$bookName》不存在,删除失败")
    else {
      println(s"《$bookName》存在,删除成功")
      BookList-=rs2.get
    }

    //7
    val id = "002"
    val rs3=BookList.find(_.id==id)
    if(rs3.isEmpty)
      println(s"$id 不存在,删除失败")
    else {
      println(s"$id 存在,删除成功")
      BookList-=rs3.get
    }

    //8
    val orderList=BookList.sortWith((a,b)=>a.price>b.price)

    //9
    orderList.foreach(el=>{
      println(s"书名${el.bookName},作者${el.author},价格${el.price},数量${el.amount}")
    })

    //10
    var sum:Double=0
    BookList.foreach((el=>{
      sum+=(el.amount*el.price)
    }))
    println(s"总的金额是:${sum}")
  }
}
相关推荐
哈哈很哈哈2 天前
Spark 核心 RDD详解
大数据·分布式·spark·scala
DTS小夏3 天前
Linux 系统 + IDEA+Scala 插件:新手进阶开发指南
linux·scala·intellij-idea
渣渣盟4 天前
Spark核心:单跳转换率计算全解析
大数据·spark·scala·apache
闯闯桑5 天前
Spark 中spark.implicits._ 中的 toDF和DataFrame 类本身的 toDF 方法
大数据·ajax·spark·scala
MOMO陌染8 天前
IDEA环境搭建与输出
scala
闯闯桑10 天前
toDF(columns: _*) 语法
开发语言·前端·spark·scala·apache
q5673152311 天前
无需Python:Shell脚本如何成为你的自动化爬虫引擎?
开发语言·爬虫·python·自动化·scala
渣渣盟13 天前
Spark自定义累加器实现高效WordCount
大数据·spark·scala
IvanCodes13 天前
一、Scala 基础语法、变量与数据类型
大数据·开发语言·scala
q5673152314 天前
Nim轻量级爬虫:异步高效+代理轮换防封
开发语言·后端·爬虫·typescript·scala