快学Scala习题解答—第四章 映射和元组
4.1 设置一个映射,当中包括你想要的一些装备,以及它们的价格。然后构建还有一个映射。採用同一组键,可是价格上打9折
映射的简单操作
- scala> val map = Map("book"->10,"gun"->18,"ipad"->1000)
- map: scala.collection.immutable.Map[java.lang.String,Int] = Map(book -> 10, gun -> 18, ipad -> 1000)
- scala> for((k,v) <- map) yield (k,v * 0.9)
- 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代码例如以下
- import scala.io.Source
- import scala.collection.mutable.HashMap
- //val source = Source.fromFile("myfile.txt")
- //val tokens = source.mkString.split("\\s+") //此写法tokens为空,不知为何
- val source = Source.fromFile("myfile.txt").mkString
- val tokens = source.split("\\s+")
- val map = new HashMap[String,Int]
- for(key <- tokens){
- map(key) = map.getOrElse(key,0) + 1
- }
- println(map.mkString(","))
4.3 反复前一个练习,这次用不可变的映射
不可变映射与可变映射的差别就是,每次加入元素,都会返回一个新的映射
- import scala.io.Source
- val source = Source.fromFile("myfile.txt").mkString
- val tokens = source.split("\\s+")
- var map = Map[String,Int]()
- for(key <- tokens){
- map += (key -> (map.getOrElse(key,0) + 1))
- }
- println(map.mkString(","))
4.4 反复前一个练习。这次使用已排序的映射。以便单词能够按顺序打印出来
和上面的代码没有什么差别,仅仅是将映射改动为SortedMap
- import scala.io.Source
- import scala.collection.SortedMap
- val source = Source.fromFile("myfile.txt").mkString
- val tokens = source.split("\\s+")
- var map = SortedMap[String,Int]()
- for(key <- tokens){
- map += (key -> (map.getOrElse(key,0) + 1))
- }
- println(map.mkString(","))
4.5 反复前一个练习。这次使用java.util.TreeMap并使之适用于Scala API
主要涉及java与scala的转换类的使用
- import scala.io.Source
- import scala.collection.mutable.Map
- import scala.collection.JavaConversions.mapAsScalaMap
- import java.util.TreeMap
- val source = Source.fromFile("myfile.txt").mkString
- val tokens = source.split("\\s+")
- val map:Map[String,Int] = new TreeMap[String,Int]
- for(key <- tokens){
- map(key) = map.getOrElse(key,0) + 1
- }
- println(map.mkString(","))
4.6 定义一个链式哈希映射,将"Monday"映射到java.util.Calendar.MONDAY,依次类推加入其它日期。展示元素是以插入的顺序被訪问的
LinkedHashMap的使用
- import scala.collection.mutable.LinkedHashMap
- import java.util.Calendar
- val map = new LinkedHashMap[String,Int]
- map += ("Monday"->Calendar.MONDAY)
- map += ("Tuesday"->Calendar.TUESDAY)
- map += ("Wednesday"->Calendar.WEDNESDAY)
- map += ("Thursday"->Calendar.THURSDAY)
- map += ("Friday"->Calendar.FRIDAY)
- map += ("Saturday"->Calendar.SATURDAY)
- map += ("Sunday"->Calendar.SUNDAY)
- println(map.mkString(","))
4.7 打印出全部Java系统属性的表格
属性转scala map的使用
- import scala.collection.JavaConversions.propertiesAsScalaMap
- val props:scala.collection.Map[String,String] = System.getProperties()
- val keys = props.keySet
- val keyLengths = for( key <- keys ) yield key.length
- val maxKeyLength = keyLengths.max
- for(key <- keys) {
- print(key)
- print(" " * (maxKeyLength - key.length))
- print(" | ")
- println(props(key))
- }
4.8 编写一个函数minmax(values:Array[Int]),返回数组中最小值和最大值的对偶
- def minmax(values:Array[Int])={
- (values.max,values.min)
- }
4.9 编写一个函数Iteqgt(values:Array[int],v:Int),返回数组中小于v,等于v和大于v的数量。要求三个值一起返回
- def iteqgt(values:Array[Int],v:Int)={
- val buf = values.toBuffer
- (values.count(_ < v),values.count(_ == v),values.count(_ > v))
- }
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
快学Scala习题解答—第四章 映射和元组相关推荐
- 快学Scala习题解答—第三章 数组相关操作
原文链接:http://blog.csdn.net/ivan_pig/article/details/8257365 ----------------------------------------- ...
- 快学Scala习题解答—第一章 基础
原文链接:http://blog.csdn.net/ivan_pig/article/details/8249768 ----------------------------------------- ...
- 快学Scala习题解答—第二章 控制结构和函数
原文地址:http://blog.csdn.net/ivan_pig/article/details/8253068 ----------------------------------------- ...
- 快学Scala习题解答—第十章 特质
10 特质 10.1 java.awt.Rectangle类有两个非常实用的方法translate和grow,但可惜的是像java.awt.geom.Ellipse2D这种类没有. 在Scala中,你 ...
- 《学习OpenCV》课后习题解答(第四章)(仅供参考)(不断更新)
代码在VS2008下通过,要在附加依赖项中添加:opencv_core220d.lib opencv_highgui220d.lib opencv_imgproc220d.lib.也可以在代码里面添加 ...
- python教材答案第四章_python核心编程课后习题解答第四章
4–1. Python 对象.与所有Python 对象有关的三个属性是什么?请简单的描述一下. type.ID.value..(身份.类型.值) type()接受一个对象作为参数,并返回它的类型 id ...
- 电路习题解答 第四章 4-25
戴维南等效电路和诺顿等效电路,总体上核心思想就是求开路电压和等效电阻. 开路电压Uoc求解: 使用KCL.KVL.VCR.节点电压法,一般就能够求出来. 等效电阻Req求解: 1.对于没有受控源的电路 ...
- 《快学scala第二版》第一章 练习答案
1.1 在Scala REPL中键入3.然后按Tab键.有哪些方法可以被应用? 1.2 在Scala REPL中,计算3的平方根,然后再对该值求平方.现在,这个结果与3相差多少?(提示:res变量是你 ...
- 电路习题解答 第四章 4-9、4-10
最新文章
- 一次失败的尝试:paxosstore示例编译
- AsyncTask进度条加载网站数据到ListView
- Spring bean 之 FactoryBean
- 现代农业谋定县域经济-农业大健康·万祥军:载体幸福美丽
- 20210625 函数的极限
- 文献记录(part14)--Biclustering with dominant sets
- [转]关于数据库的并发性的一个解决方案
- Interfaces
- ajax php 错误提示,php – jQuery AJAX错误处理
- PowerShell实战5: 批量增加AD组成员
- 周易 —— 文本阅读
- 21-7-28 git学习复习
- php 调用永中云,永中优云:是时候给大家介绍真正的云端Office了
- 《信号与系统学习笔记》—线性时不变系统(二)
- sai教程初识SAI + 城堡绘画教程
- FFmpeg的下载及其简单使用
- Simulink代码生成基础体验教程
- MySQL过期数据归档和清理--pt--archiver
- word打不开服务器无响应,word文档打开后未响应怎么办 word打开后一直未响应
- NL2SQL领域:RAT-SQL论文笔记