[关闭]
@amoszhou 2014-05-07T06:37:36.000000Z 字数 1482 阅读 1876

第四章:映射与元组

scala课后习题


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

  1. def percentMap(map : Map[String,Float])={
  2. for((name,price) <- map) yield (name,price*0.9)
  3. }

2.编写一段程序,从文件中读取单词。用一个可变映射来清点每个单词出现的频率。读取这些单词的操作可以使用java.util.Scanner.最后,打印出所有单词和它们出现的次数。

  1. def wordCount(file:String)={
  2. val words = Source.fromFile(file).mkString
  3. val wordArray = words.split(" ")
  4. val map = new HashMap[String,Int]
  5. for(word <- wordArray){
  6. map(word)=map.getOrElse(word,0)+1
  7. }
  8. }

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

  1. def wordCount2(file :String)={
  2. val source = Source.fromFile("myfile.txt").mkString
  3. val tokens = source.split(" ")
  4. var map = Map[String,Int]()
  5. for(key <- tokens){
  6. map += (key -> (map.getOrElse(key,0) + 1))
  7. }
  8. }

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

这题主要是考LinkedHashMap

  1. val map = new LinkedHashMap[String,Int]
  2. map += ("Monday"->Calendar.MONDAY)
  3. map += ("Tuesday"->Calendar.TUESDAY)
  4. map += ("Wednesday"->Calendar.WEDNESDAY)
  5. map += ("Thursday"->Calendar.THURSDAY)
  6. map += ("Friday"->Calendar.FRIDAY)
  7. map += ("Saturday"->Calendar.SATURDAY)
  8. map += ("Sunday"->Calendar.SUNDAY)

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

  1. def minmax(values:Array[Int])={
  2. (values.max,values.min)
  3. }

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

  1. def iteqgt(values:Array[Int],v:Int)={
  2. val buf = values.toBuffer
  3. (values.count(_ < v),values.count(_ == v),values.count(_ > v))
  4. }

7. 当你将两个字符串拉链在一起,比如"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))

这个主要是去看StringOps里面的zip方法定义。

添加新批注
在作者公开此批注前,只有你和作者可见。
回复批注