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}")
}
}
Scala例题
刘翔在线犯法2024-11-14 14:56
相关推荐
老朱佩琪!3 分钟前
Unity原型模式毕设源码-郭学长4 分钟前
【开题答辩全过程】以 基于JAVA的车辆违章信息管理系统设计及实现为例,包含答辩的问题和答案while(1){yan}4 分钟前
UDP和TCP的核心后端小张9 分钟前
【Java 进阶】深入理解Redis:从基础应用到进阶实践全解析武子康27 分钟前
大数据-189 Nginx JSON 日志接入 ELK:ZK+Kafka+Elasticsearch 7.3.0+Kibana 实战搭建码海踏浪28 分钟前
JMeter 时间函数合集麦麦鸡腿堡29 分钟前
Java_反射暴破创建对象与访问类中的成员不会c嘎嘎29 分钟前
深入理解QT之信号和槽SunnyDays101130 分钟前
Python 实现 PDF 文档压缩:完整指南Cx330❀30 分钟前
《C++ 动态规划》第001-002题:第N个泰波拉契数,三步问题