`
Ivan_Pig
  • 浏览: 387100 次
  • 性别: Icon_minigender_1
  • 来自: 南京
社区版块
存档分类
最新评论

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

阅读更多
5 映射和元组

5.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)


5.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(","))


5.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(","))


5.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(","))


5.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(","))


5.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(","))


5.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))
}


5.8 编写一个函数minmax(values:Array[Int]),返回数组中最小值和最大值的对偶
def minmax(values:Array[Int])={
  (values.max,values.min)
}


5.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))
}


5.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来说,它是可遍历的。但是它的遍历是遍历单个字母。 所以拉链就针对每个字母来进行。

[b]Blog URL:
http://www.ivanpig.com/blog/?p=464
0
0
分享到:
评论

相关推荐

    快学scala习题及答案详解

    描述中提到的三份文档——"快学scala第一章习题答案.doc"、"快学scala第二章习题答案.doc"、"快学scala第三章习题答案.doc"——暗示了这份学习资料是按照章节结构编排的,每个章节都有对应的习题和详尽的答案。...

    Scala映射和元组.md

    Scala映射和元组.md

    读书笔记:《快学Scala》课后习题解答.zip

    读书笔记:《快学Scala》课后习题解答

    快学scala的习题和答案

    快学scala的习题和答案,对学习scala有巨大帮助,可以好好学习scala,在学习的过程中可以边看边练习~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~

    快学scala 完整

    快学scala 完整清晰版 大数据spark 主要的编程语言 快学scala 完整清晰版 大数据spark 主要的编程语言

    快学Scala-课后习题答案-源码

    这个"快学Scala"的课后习题答案和源码将涵盖以上提到的大部分知识点,通过实际操作和练习,你可以深入理解Scala的各个方面。解压文件后,可以直接导入到IDE(如IntelliJ IDEA或Scala IDE),按照章节顺序逐步学习,...

    快学Scala 课后习题答案集合

    "快学Scala"系列教程可能涵盖了语言基础、类与对象、高阶函数、模式匹配、类型系统、Actor模型以及 Akka 框架等内容。课后习题是学习过程中巩固知识的重要环节,这里我们将深入探讨这些习题答案集合中的关键知识点。...

    快学scala答案总汇

    "快学Scala答案总汇"很显然是一个针对Scala初学者或正在学习Scala的人提供的资源,包含了对课程或书籍中习题的解答,帮助读者更好地理解和掌握Scala的核心概念。 1. **基础语法**:Scala的基础语法与Java有诸多不同...

    快学Scala 课后习题答案集合-中文版

    这个“快学Scala 课后习题答案集合-中文版”涵盖了Scala学习中的关键知识点,包括注解(第十五章)和高级类型(第十八章)等主题。下面将对这些主题进行详细的解释。 **注解(Annotations)** 在Scala中,注解是一种元...

    快学Scala课后习题答案

    这个"快学Scala课后习题答案集合"资源将帮助学习者核对自己的解答,理解错误之处,并加深对Scala语言特性的认识。通过对比答案,学习者可以发现自己的不足,从而针对性地加强学习。无论是在基础概念还是在高级特性上...

    快学Scala.中文完整版

    《快学Scala》是一门以Java虚拟机(JVM)为目标运行环境并将面向对象和函数式编程语言的特性结合在一起的编程语言。你可以使用Scala编写出更加精简的程序,同时充分利用并发的威力。由于Scala运行于JVM之上,因此它...

    快学 scala 中文版 带完整目录

    第4章 映射和元组 A1 53 4.1 构造映射 53 4.2 获取映射中的值 54 4.3 更新映射中的值 55 4.4 迭代映射 56 4.5 已排序映射 57 4.6 与Java的互操作 57 4.7 元组 58 4.8 拉链操作 59 练习 60 第5章 类 A1 63 ...

    快学 Scala(第二版) Second Edition

    通过阅读《快学 Scala(第二版)》,读者不仅可以学习Scala的基本语法和高级特性,还能了解到如何在大数据处理领域(如Spark)和流处理(如Kafka)中有效地运用这些知识。书中的例子和练习将帮助读者快速掌握这些技能...

    快学Scala 中文版

    "快学Scala 中文版"是一本专为初学者设计的 Scala 入门书籍,它以清晰易懂的方式介绍了 Scala 的核心概念和技术。 在本书中,读者将首先了解到 Scala 的基本语法,包括变量声明、数据类型(如基本类型、引用类型、...

    快学scala2带书签、源码

    "快学Scala2带书签、源码"是一个针对初学者和有一定经验的开发者的资源包,旨在帮助他们快速掌握Scala语言的第二版。** 在《快学Scala》第二版这本著作中,作者通过简洁易懂的讲解,深入浅出地介绍了Scala的基础...

    快学scala中文版带目录

    快学scala中文版带目录,清晰 快学scala中文版带目录,清晰 快学scala中文版带目录,清晰 快学scala中文版带目录,清晰 快学scala中文版带目录,清晰 快学scala中文版带目录,清晰 快学scala中文版带目录,清晰

    快学Scala 电子书 pdf

    花了5元订制的快学Scala pdf电子书! Scala是一门以Java虚拟机(JVM)为目标运行环境并将面向对象和函数式编程语言的最佳特性结合在一起的编程语言。你可以使用Scala编写出更加精简的程序,同时充分利用并发的威力...

    快学Scala 中文版带目录

    《快学Scala中文版》是一本专为初学者和有一定编程基础的学习者设计的Scala语言教程,旨在帮助读者快速掌握Scala编程的核心概念和技术。Scala是一种多范式编程语言,融合了面向对象和函数式编程的特点,广泛应用于大...

Global site tag (gtag.js) - Google Analytics