快学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. scala> for((k,v) <- map) yield (k,v * 0.9)
  4. 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. //val source = Source.fromFile("myfile.txt")
  4. //val tokens = source.mkString.split("\\s+")  //此写法tokens为空,不知为何
  5. val source = Source.fromFile("myfile.txt").mkString
  6. val tokens = source.split("\\s+")
  7. val map = new HashMap[String,Int]
  8. for(key <- tokens){
  9. map(key) = map.getOrElse(key,0) + 1
  10. }
  11. println(map.mkString(","))

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

不可变映射与可变映射的区别就是,每次添加元素,都会返回一个新的映射

Scala代码  

  1. import scala.io.Source
  2. val source = Source.fromFile("myfile.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 重复前一个练习,这次使用已排序的映射,以便单词可以按顺序打印出来

和上面的代码没有什么区别,只是将映射修改为SortedMap

Scala代码  

  1. import scala.io.Source
  2. import scala.collection.SortedMap
  3. val source = Source.fromFile("myfile.txt").mkString
  4. val tokens = source.split("\\s+")
  5. var map = SortedMap[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

主要涉及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. val source = Source.fromFile("myfile.txt").mkString
  6. val tokens = source.split("\\s+")
  7. val map:Map[String,Int] = new TreeMap[String,Int]
  8. for(key <- tokens){
  9. map(key) = map.getOrElse(key,0) + 1
  10. }
  11. println(map.mkString(","))

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

LinkedHashMap的使用

Scala代码  

  1. import scala.collection.mutable.LinkedHashMap
  2. import java.util.Calendar
  3. val map = new LinkedHashMap[String,Int]
  4. map += ("Monday"->Calendar.MONDAY)
  5. map += ("Tuesday"->Calendar.TUESDAY)
  6. map += ("Wednesday"->Calendar.WEDNESDAY)
  7. map += ("Thursday"->Calendar.THURSDAY)
  8. map += ("Friday"->Calendar.FRIDAY)
  9. map += ("Saturday"->Calendar.SATURDAY)
  10. map += ("Sunday"->Calendar.SUNDAY)
  11. println(map.mkString(","))

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

属性转scala map的使用

Scala代码  

  1. import scala.collection.JavaConversions.propertiesAsScalaMap
  2. val props:scala.collection.Map[String,String] = System.getProperties()
  3. val keys = props.keySet
  4. val keyLengths = for( key <- keys ) yield key.length
  5. val maxKeyLength = keyLengths.max
  6. for(key <- keys) {
  7. print(key)
  8. print(" " * (maxKeyLength - key.length))
  9. print(" | ")
  10. println(props(key))
  11. }

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

版权声明:本文为博主原创文章,未经博主允许不得转载。

时间: 2024-08-11 21:28:58

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

快学scala习题解答--第五章 类

5 类 5.1 改进5.1节的Counter类,让它不要在Int.MaxValue时变成负数 Scala代码   class Count{ private var value = Int.MaxValue def increment(){if(value < Int.MaxValue) value + 1 else value } def current = value } 5.2 编写一个BankAccount类,加入deposit和withdraw方法,和一个只读的balance属性 Sca

快学Scala习题解答—第三章 数组相关操作

3 数组相关操作 3.1 编写一段代码,将a设置为一个n个随机整数的数组,要求随机数介于0(包含)和n(不包含)之间 random和yield的使用 Scala代码   import scala.math.random def randomArray(n:Int)={ for(i <- 0 until n) yield (random * n).toInt } println(randomArray(10).mkString(",")) 3.2 编写一个循环,将整数数组中相邻的元

快学Scala习题解答—第十一章 操作符

11 操作符 11.1 依据优先级规则,3 + 4 -> 5和3 -> 4 + 5是怎样被求值的? 在REPL中运行就可以得到结果.都是从左至右运行 12.2 BigInt类有一个pow方法,但没实用操作符字符. Scala类库的设计者为什么没有选用**(像Fortran那样)或者^(像Pascal那样)作为乘方操作符呢? Scala中的操作符就是方法.其优先级是依据首字母来推断的,优先级例如以下 最高优先级:除下面字符外的操作符字符 * / % + - : = ! < > &am

快学Scala习题解答—第一章 基础

1 简介 近期对Scala比较感兴趣,买了本<快学Scala>,感觉不错.比<Programming Scala:Tackle Multi-Core Complexity on the Java Virtual Machine>好很多. 是本不错的入门书.而且每个章节都设置了难度级别,每章有习题,可以巩固Scala语法. 本文的目的就是针对这些习题进行解答 2 基础 2.1 在Scala REPL中键入3,然后按Tab键.有哪些方法可以被应用? 这个....直接操作一遍就有结果了.

快学Scala习题解答—第二章 控制结构和函数

2 控制结构和函数 2.1 一个数字如果为正数,则它的signum为1;如果是负数,则signum为-1;如果为0,则signum为0.编写一个函数来计算这个值 简单的逻辑判断 Scala代码   def signum(num:Int){if(num>0)print(1)else if(num<0)print(-1)else print(0)} Scala中已经有此方法了,刚才查找API的时候,应该能看到 Scala代码   BigInt(10).signum 2.2 一个空的块表达式{}的值

快学Scala习题解答—第八章 继承

8 继承 8.1 扩展如下的BankAccount类,新类CheckingAccount对每次存款和取款都收取1美元的手续费class BankAccount(initialBalance:Double){ private var balance = initialBalance def deposit(amount:Double) = { balance += amount; balance} def withdraw(amount:Double) = {balance -= amount;

快学Scala-第四章 映射和元组

知识点: 1.构造映射,映射是对偶的集合 val scores1 = Map("Alice" -> 10, "Bob" -> 7, "Cindy" -> 9) //不可变映射 // val scores1 = Map(("Alice",),("Bob",),("Cindy",)) val scores2 = scala.collection.mutable.Map(&q

快学Scala 第五课 (构造映射,获取映射值,更新映射值,迭代映射,与Java互操作)

构造映射: val score = Map[String, Int]() val score1 = HashMap[String, Int]() val value1 = Map[String, Int]("aa" -> 1, "bb" -> 2) val value2 = Map[String, Int](("aa", 1), ("bb", 2)) 获取映射值: println(if(value2.contain

快学scala 第十一章 操作符 读书笔记及习题答案代码

chapter 11 操作符 标签:快学scala 一.笔记 scala种可以在反引号中包含几乎任何字符序列, val 'val' = 42 所有的操作符都是左结合的,除了以冒号(:)结尾的操作符,和赋值操作符.用于构造列表的::操作符是又结合的.1::2::Ni1的意思是1::(2::Ni1),先创建出包含2的列表,这个列表又被作为尾巴拼接到以1作为头部的列表中. 2. 函数调用语法:f(arg1, arg2,...)扩展到可以应用于函数之外的值,如果f不是函数或方法,那么这个表达式等于f.a