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}")
  }
}
相关推荐
小伍_Five3 天前
Spark实战能力测评模拟题精析【模拟考】
java·大数据·spark·scala·intellij-idea
黄雪超3 天前
DataStreamAPI实践原理——快速上手(实操详细版)
大数据·flink·scala
白总Server5 天前
C++语法架构解说
java·网络·c++·网络协议·架构·golang·scala
vortex55 天前
Perl One-liner 数据处理——基础语法篇【匠心】
开发语言·scala·perl
老兵发新帖7 天前
Coursier:安装sbt
scala
请你喝好果汁64110 天前
indel_snp_ssr_primer
大数据·开发语言·scala
MZWeiei13 天前
Spark 中,map和foreach的区别
大数据·分布式·spark·scala
MZWeiei14 天前
区分:union(),coalesce () 和 repartition ()
大数据·分布式·spark·scala
北漂老男孩14 天前
Scala与Spark:原理、实践与技术全景详解
大数据·开发语言·spark·scala·学习方法
MZWeiei15 天前
Spark 中,创建 DataFrame 的方式(Scala语言)
大数据·分布式·spark·scala