快学Scala习题解答—第四章 映射和元组

4 映射和元组  

4.1 设置一个映射,当中包括你想要的一些装备,以及它们的价格。然后构建还有一个映射。採用同一组键,可是价格上打9折  
映射的简单操作 
Shell代码   收藏代码
  1. scala> val map = Map("book"->10,"gun"->18,"ipad"->1000)  
  2. map: scala.collection.immutable.Map[java.lang.String,Int] = Map(book -> 10, gun -> 18, ipad -> 1000)  
  3.   
  4. scala> for((k,v) <- map) yield (k,v * 0.9)  
  5. res3: scala.collection.immutable.Map[java.lang.String,Double] = Map(book -> 9.0, gun -> 16.2, ipad -> 900.0)  


4.2 编写一段程序,从文件里读取单词。用一个可变映射来清点每一个单词出现的频率。读取这些单词的操作能够使用java.util.Scanner: 
val in = new java.util.Scanner(new java.io.File("myfile.txt")) while(in.hasNext()) 处理 in.next() 或者翻到第9章看看更Scala的做法。

最后,打印出全部单词和它们出现的次数。

 
当然使用Scala的方法啦。參考第9章 
首先。创建一个文件myfile.txt。输入例如以下内容 
test test ttt test ttt t test sss s 
Scala代码例如以下 
Scala代码   收藏代码
  1. import scala.io.Source  
  2. import scala.collection.mutable.HashMap  
  3.   
  4. //val source = Source.fromFile("myfile.txt")  
  5. //val tokens = source.mkString.split("\\s+")  //此写法tokens为空,不知为何  
  6.   
  7. val source = Source.fromFile("myfile.txt").mkString  
  8.   
  9. val tokens = source.split("\\s+")  
  10.   
  11. val map = new HashMap[String,Int]  
  12.   
  13. for(key <- tokens){  
  14.     map(key) = map.getOrElse(key,0) + 1  
  15. }  
  16.   
  17. println(map.mkString(","))  


4.3 反复前一个练习,这次用不可变的映射 
不可变映射与可变映射的差别就是,每次加入元素,都会返回一个新的映射
 
Scala代码   收藏代码
  1. import scala.io.Source  
  2.   
  3. val source = Source.fromFile("myfile.txt").mkString  
  4.   
  5. val tokens = source.split("\\s+")  
  6.   
  7. var map = Map[String,Int]()  
  8.   
  9. for(key <- tokens){  
  10.   map += (key -> (map.getOrElse(key,0) + 1))  
  11. }  
  12.   
  13. println(map.mkString(","))  


4.4 反复前一个练习。这次使用已排序的映射。以便单词能够按顺序打印出来 
和上面的代码没有什么差别,仅仅是将映射改动为SortedMap
 
Scala代码   收藏代码
  1. import scala.io.Source  
  2. import scala.collection.SortedMap  
  3.   
  4. val source = Source.fromFile("myfile.txt").mkString  
  5.   
  6. val tokens = source.split("\\s+")  
  7.   
  8. var map = SortedMap[String,Int]()  
  9.   
  10. for(key <- tokens){  
  11.   map += (key -> (map.getOrElse(key,0) + 1))  
  12. }  
  13.   
  14. println(map.mkString(","))  


4.5 反复前一个练习。这次使用java.util.TreeMap并使之适用于Scala API  
主要涉及java与scala的转换类的使用 
Scala代码   收藏代码
  1. import scala.io.Source  
  2. import scala.collection.mutable.Map  
  3. import scala.collection.JavaConversions.mapAsScalaMap  
  4. import java.util.TreeMap  
  5.   
  6. val source = Source.fromFile("myfile.txt").mkString  
  7.   
  8. val tokens = source.split("\\s+")  
  9.   
  10. val map:Map[String,Int] = new TreeMap[String,Int]  
  11.   
  12. for(key <- tokens){  
  13.   map(key) = map.getOrElse(key,0) + 1  
  14. }  
  15.   
  16. println(map.mkString(","))  


4.6 定义一个链式哈希映射,将"Monday"映射到java.util.Calendar.MONDAY,依次类推加入其它日期。展示元素是以插入的顺序被訪问的  
LinkedHashMap的使用 
Scala代码   收藏代码
  1. import scala.collection.mutable.LinkedHashMap  
  2. import java.util.Calendar  
  3.   
  4. val map = new LinkedHashMap[String,Int]  
  5.   
  6. map += ("Monday"->Calendar.MONDAY)  
  7. map += ("Tuesday"->Calendar.TUESDAY)  
  8. map += ("Wednesday"->Calendar.WEDNESDAY)  
  9. map += ("Thursday"->Calendar.THURSDAY)  
  10. map += ("Friday"->Calendar.FRIDAY)  
  11. map += ("Saturday"->Calendar.SATURDAY)  
  12. map += ("Sunday"->Calendar.SUNDAY)  
  13.   
  14.   
  15. println(map.mkString(","))  


4.7 打印出全部Java系统属性的表格  
属性转scala map的使用 
Scala代码   收藏代码
  1. import scala.collection.JavaConversions.propertiesAsScalaMap  
  2.   
  3. val props:scala.collection.Map[String,String] = System.getProperties()  
  4.   
  5. val keys = props.keySet  
  6.   
  7. val keyLengths = for( key <- keys ) yield key.length  
  8.   
  9. val maxKeyLength = keyLengths.max  
  10.   
  11. for(key <- keys) {  
  12.   print(key)  
  13.   print(" " * (maxKeyLength - key.length))  
  14.   print(" | ")  
  15.   println(props(key))  
  16. }  


4.8 编写一个函数minmax(values:Array[Int]),返回数组中最小值和最大值的对偶  
Scala代码   收藏代码
  1. def minmax(values:Array[Int])={  
  2.   (values.max,values.min)  
  3. }  


4.9 编写一个函数Iteqgt(values:Array[int],v:Int),返回数组中小于v,等于v和大于v的数量。要求三个值一起返回  
Scala代码   收藏代码
  1. def iteqgt(values:Array[Int],v:Int)={  
  2.   val buf = values.toBuffer  
  3.   (values.count(_ < v),values.count(_ == v),values.count(_ > v))  
  4. }  


4.10 当你将两个字符串拉链在一起,比方"Hello".zip("World"),会是什么结果?想出一个讲得通的用例  
scala> "Hello".zip("World") 
res0: scala.collection.immutable.IndexedSeq[(Char, Char)] = Vector((H,W), (e,o), (l,r), (l,l), (o,d))  
StringOps中的zip定义例如以下 
abstract def zip (that: GenIterable[B]): StringOps[(A, B)] 

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

原博客地址:http://www.ivanpig.com/blog/?

p=464

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
快学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、付费专栏及课程。

余额充值