Scala例题

复制代码
package Scala3

import scala.collection.mutable.ListBuffer

//1
case class Book(var ID:String,var bookName: String, var author: String,var price: Double,var number:Int) {

}
object timu {
  def main(args: Array[String]): Unit = {
    //2
    val BookList=ListBuffer[Book]()
    //3
    BookList+=new Book("001","西游记","吴承恩",23.4,100)
    BookList+=new Book("002","星际远航:宇宙边缘的探索者"," 林羽",69,100)
    BookList+=new Book("003","时间裂缝:错乱时空的冒险","苏晓",78,28)
    println(BookList)
    //4.添加一本书
    val book1=Book("002","星际远航:宇宙边缘的探索者"," 林羽",69,100)
//    //如果已经包含这本书,直接去修改数量
//    for(b<-BookList){
      println(b.ID)
//      if(b.ID==book1.ID){//同一本书
        println(b)
//        b.number+=book1.number
//        println(b)
//
//      }
//    }
    //查找,是否ID为book.ID的元素,找到就返回,没有找到,就返回None
    val rs=BookList.find(_.ID==book1.ID)
    println(rs)
    if(rs.isEmpty){
      println("没有")
      BookList+=book1
    }else{
      println("有")
      val s=rs.get//拿出具体的数据
      s.number+=book1.number//数量增加
    }
    //5,根据名称去查询
    var bookName="三体"
    val rs1=BookList.find(_.bookName==bookName)
    if(rs1.isEmpty){
      println(s"《$bookName》不存在")
    }else{
      println(s"《$bookName》存在")
    }

    //6.删除指定书名的书
    bookName = "三体"
    val rs2 = BookList.find(_.bookName == bookName)
    if (rs2.isEmpty) {
      println(s"《$bookName》不存在,删除失败")
    } else {
      println(s"《$bookName》存在,删除成功")
      BookList-=rs2.get
    }
    //7.删除指定ID
    var id = "三体"
    val rs3 = BookList.find(_.ID == id)
    if (rs3.isEmpty) {
      println(s"id:$id 不存在,删除失败")
    } else {
      println(s"id:$id 存在,删除成功")
      BookList -= rs3.get
    }

    //8.价格顺序
    val or=BookList.sortWith((a,b)=>a.price>b.price)
    println(or)
    //9.遍历
    BookList.foreach(el=>{
      println(s"书名:${el.bookName},作者:${el.author},价格:${el.price},数量:${el.number}")

    })
    //10.计算全部金额
    var sum:Double=0
    BookList.foreach((w=>{
      sum+=(w.number*w.price)
    }))
    println(s"总的金额是:${sum}")



    }


}
相关推荐
满分观察网友z3 分钟前
从混乱到有序:我用“逐层扫描”法优雅搞定公司组织架构图(515. 在每个树行中找最大值)
后端·算法
钮钴禄·爱因斯晨4 分钟前
C语言 | 函数核心机制深度解构:从底层架构到工程化实践
c语言·开发语言·数据结构
wkj0016 分钟前
php中array($this, ‘loadClass‘)表示啥意思?
android·开发语言·php
Stuomasi_xiaoxin7 分钟前
服务器重装后如何“复活”旧硬盘上的 Anaconda 环境?—— 一次完整的排错与恢复记录
开发语言·python·github
风象南8 分钟前
SpringBoot应用开机自启动与进程守护配置
java·spring boot·后端
寻月隐君10 分钟前
Rust核心利器:枚举(Enum)与模式匹配(Match),告别空指针,写出优雅健壮的代码
后端·rust·github
满分观察网友z10 分钟前
一行代码的惊人魔力:从小白到大神,我用递归思想解决了TB级数据难题(3304. 找出第 K 个字符 I)
后端·算法
程序员岳焱12 分钟前
Java 与 MySQL 性能优化:MySQL连接池参数优化与性能提升
后端·mysql·性能优化
这里有鱼汤12 分钟前
一招横盘突破选股法,赚钱不靠运气靠图形,靠概率!
后端·python
万少23 分钟前
鸿蒙外包的十大生存法则
前端·后端·面试