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}")
  }
}
相关推荐
qwy7152292581632 天前
3-scala的类
开发语言·后端·scala
qwy7152292581636 天前
4.scala默认参数值
开发语言·后端·scala
百流9 天前
scala基础学习(数据类型)-哈希表
学习·scala·散列表
李匠20249 天前
大数据学习之SCALA分布式语言三
开发语言·学习·scala
lisacumt10 天前
【kerberos】使用keytab文件,kerberos认证工具类 scala版本
hadoop·scala
百流11 天前
scala文件编译相关理解
开发语言·学习·scala
WorkAgent11 天前
windows下本地部署安装hadoop+scala+spark-【不需要虚拟机】
hadoop·spark·scala
JoneMaster18 天前
[读书日志]从零开始学习Chisel 第十二篇:Scala的抽象成员(敏捷硬件开发语言Chisel与数字系统设计)
开发语言·学习·scala
wlyang66621 天前
4. scala高阶之隐式转换与泛型
大数据·开发语言·后端·spark·scala
一杯拿铁go22 天前
[sparkstreaming]java.lang.NoSuchMethodError:错误以及更改
scala·noclassdeffound