快学scala 第四章 读书笔记及习题答案代码

chapter 4 元组与映射

标签:快学scala


一、笔记

  1. 默认Map为不可变映射,可变映射定义:
 
 
  1. scala> val scores = scala.collection.mutable.Map("Allic"->1, "Bob"->3, "Cindy"->8)
  2. scala> val scores = new scala.collection.mutable.HashMap[String, Int] //空映射
  3. scores: scala.collection.mutable.HashMap[String,Int] = Map()

获取map中的值:

 
 
  1. scala> val bobscore = scores("Bob")
  2. bobscore: Int = 3
  3. scala> val bobscore = if(scores.contains("Bob")) scores("Bob") else 0 //检查操作
  4. bobscore: Int = 3
  5. //简写
  6. scala> val bobscore = scores.getOrElse("Bob",0)
  7. bobscore: Int = 3
  8. //更新操作
  9. scala> val newscore = scores + (("Bob", 10),("Fred", 7))
  10. newscore: scala.collection.mutable.Map[String,Int] = Map(Allic -> 1, Bob -> 10, Fred -> 7, Cindy -> 8)
  1. 迭代映射 scores.keyset 关键字的集合; socres.value值 
    for(v <- scores.values) println(v) 
    for((k, v) <- socres) yield(v,k) //反转映射
  2. 键值是键/值对偶的集合,对偶是元组的最简单形式,tuple是不同类型的值的聚集。元组的各组员从1开始,而不是0. 元组可以用于函数需要返回不止一个值的情况:
 
 
  1. scala> "New York".partition(_.isUpper)
  2. res2: (String, String) = (NY,ew ork)
  1. 拉链操作
 
 
  1. scala> "New York".partition(_.isUpper)
  2. res2: (String, String) = (NY,ew ork)
  3. scala> val symbols=Array("<", "-",">")
  4. symbols: Array[String] = Array(<, -, >)
  5. scala> val counts = Array(2,10,2)
  6. counts: Array[Int] = Array(2, 10, 2)
  7. scala> val pairs= symbols.zip(counts)
  8. pairs: Array[(String, Int)] = Array((<,2), (-,10), (>,2))
  9. scala> for((s,n)<- pairs)Console.print(s * n)
  10. <<---------->>

二、习题答案

4.1 设置一个映射,其中包含你想要的一些装备,以及它们的价格。然后构建另一个映射,采用同一组键,但是价格上打9折

 
 
  1. def equipment(): Map[String, Double]={
  2. val equipmap :Map[String, Double] = Map(("eq1",10.8),("eq2",12.2),("eq3",13.3))
  3. for((n,k) <- equipmap) yield(n,k*0.9)
  4. }
  5. println(equipment().mkString(","))

4.2 编写一段程序,从文件中读取单词。用一个可变映射来清点每个单词出现的频率。读取这些单词的操作可以使用java.util.Scanner

 
 
  1. import scala.io.Source
  2. import scala.collection.mutable.HashMap
  3. val source = Source.fromFile("test.txt").mkString
  4. println(source)
  5. val tokens = source.split("\\s+") //"\\s"表示空格 回车 换行符 “+”表示多个的意思
  6. val map = new HashMap[String,Int]
  7. for(key <- tokens){
  8. map(key) = map.getOrElse(key,0) + 1
  9. }
  10. println(map.mkString(","))

4.3 重复前一个练习,这次用不可变的映射

 
 
  1. import scala.io.Source
  2. val source = Source.fromFile("test.txt").mkString
  3. val tokens = source.split("\\s+")
  4. var map = Map[String,Int]()
  5. for(key <- tokens){
  6. map += (key -> (map.getOrElse(key,0) + 1))
  7. }
  8. println(map.mkString(","))

4.4 重复前一个练习,这次使用已排序的映射,以便单词可以按顺序打印出来

 
 
  1. import scala.io.Source
  2. import scala.collection.immutable.TreeMap
  3. val source = Source.fromFile("test.txt").mkString
  4. val tokens = source.split("\\s+")
  5. var map = new TreeMap[String,Int]()
  6. for(key <- tokens){
  7. map += (key -> (map.getOrElse(key,0) + 1))
  8. }
  9. println(map.mkString(",")

4.5 重复前一个练习,这次使用java.util.TreeMap并使之适用于Scala API

 
 
  1. import scala.io.Source
  2. import scala.collection.JavaConversions.mapAsScalaMap
  3. val source = Source.fromFile("test.txt").mkString
  4. val tokens = source.split("\\s+")
  5. var map = new sortedMap[String,Int]()
  6. for(key <- tokens){
  7. map += (key -> (map.getOrElse(key,0) + 1))
  8. }
  9. println(map.mkString(","))

4.6 定义一个链式哈希映射,将”Monday”映射到java.util.Calendar.MONDAY,依次类推加入其他日期。展示元素是以插入的顺序被访问的

 
 
  1. import java.util.Calendar
  2. import scala.collection.mutable
  3. def calendarDays(): Unit={
  4. val daysMap = mutable.LinkedHashMap(
  5. "Monday" -> Calendar.MONDAY,
  6. "Tuesday" -> Calendar.TUESDAY,
  7. "Wednesday" -> Calendar.WEDNESDAY,
  8. "Thursday" -> Calendar.THURSDAY,
  9. "Friday" -> Calendar.FRIDAY,
  10. "Saturday" -> Calendar.SATURDAY,
  11. "Sunday" -> Calendar.SUNDAY
  12. )
  13. println(daysMap.mkString(","))
  14. }
  15. calendarDays()

4.7 打印出所有Java系统属性的表格

 
 
  1. import scala.collection.JavaConversions.propertiesAsScalaMap
  2. def printJavaSysProps():Unit = {
  3. val propMap:collection.Map[String,String] = System.getProperties()
  4. val maxKeyLength = propMap.keySet.map(_.length).max
  5. for( (k,v) <- propMap ) printf("%-" + maxKeyLength + "s | %s\n", k, v)
  6. }

4.8 编写一个函数minmax(values:Array[Int]),返回数组中最小值和最大值的对偶

 
 
  1. def minmax(values: Array[Int]) = {
  2. (values.min, values.max)
  3. }
  4. val arr = Array(1,2,3,4,5)
  5. println(minmax(arr).toString)

4.9 编写一个函数Iteqgt(values:Array[int],v:Int),返回数组中小于v,等于v和大于v的数量,要求三个值一起返回

 
 
  1. def Iteqgt(values:Array[Int],v:Int)= {
  2. (values.count(_ < v),values.count(_ == v),values.count(_ > v))
  3. }
  4. val arr = Array(1,2,3,4,5)
  5. println(Iteqgt(arr, 3).toString)

4.10 当你将两个字符串拉链在一起,比如”Hello”.zip(“World”),会是什么结果?想出一个讲得通的用例

 
 
  1. scala> "Hello".zip("World")
  2. res0: scala.collection.immutable.IndexedSeq[(Char, Char)] = Vector((H,W), (e,o), (l,r), (l,l), (o,d))
  3. StringOps中的zip定义如下:
  4. def zip[B](that: GenIterable[B]): StringOps[(A, B)]

GenIterable是可遍历对象需要包含的trait,对于String来说,它是可遍历的。但是它的遍历是遍历单个字母。所以拉链就针对每个字母来进行。

快学Scala PDF第二版》是一本非常实用的Scala编程入门指南。本书涵盖了Scala的基本概念、核心语法、函数式编程、面向对象编程、并发编程等多个方面的内容,适合初学者和有一定编程基础的读者阅读。 本书第一部分介绍了Scala的基本概念和语法,包括变量、数据类型、函数、类和对象等内容,帮助读者快速入门并掌握Scala的基础知识。第二部分介绍了Scala的函数式编程特性,包括高阶函数、匿名函数、闭包等,帮助读者理解函数式编程的思想和应用。第三部分介绍了Scala的面向对象编程特性,包括类的定义、继承、多态等,帮助读者掌握面向对象编程的基本原理和技巧。第四部分介绍了Scala的并发编程特性,包括并发基础、线程、并发集合等,帮助读者理解并发编程的概念和应用。 本书还通过大量实例和案例帮助读者加深对Scala的理解和掌握,让读者能够通过实际练习提升编程能力。此外,本书还介绍了Scala的一些高级特性和应用场景,如模式匹配、解构、隐式转换等,帮助读者更深入地学习和应用Scala编程语言。 总的来说,《快学Scala PDF第二版》是一本很不错的Scala编程入门书籍,内容丰富、通俗易懂,适合广大学习者阅读。希望读者能够通过阅读本书,快速掌握Scala编程的基础知识,并能够灵活运用到实际项目中去。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值