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}")
  }
}
相关推荐
lucky_syq4 天前
Scala与Spark算子:大数据处理的黄金搭档
开发语言·spark·scala
深兰科技6 天前
廊坊市市长刘媛率队到访深兰科技,推动机器人制造基地与产业投资落地
人工智能·科技·机器人·scala·symfony·深兰科技·廊坊市市长刘媛
萧霍10 天前
判断两个对象是相等的
scala
程序员小羊!11 天前
Flink(用Scala版本写Word Count 出现假报错情况解决方案)假报错,一直显示红色报错
flink·word·scala
173115 天前
scala中访问控制与方法重写
scala
张较瘦_16 天前
[论文阅读] 从 5MB 到 1.6GB 数据:Java/Scala/Python 在 Spark 中的性能表现全解析
java·python·scala
还是大剑师兰特21 天前
Scala面试题及详细答案100道(81-90)-- 框架与生态
scala·大剑师·scala面试题
孤岛奇兵常凯申23 天前
Scala中的高阶函数(一)
scala
盛小夏23 天前
用 Python 把汉诺塔玩成“魔法”:从递归到可视化,一篇就够!
scala
智海观潮1 个月前
学好Spark必须要掌握的Scala技术点
大数据·spark·scala