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

import scala.collection.JavaConversions.asScalaBuffer
import scala.collection.mutable.Buffer
import java.awt.datatransfer._
 
import java.util.TimeZone
object App{
  def main(args: Array[String]){
    val = Map("Mac Mini" -> 4988"MacBook Air" -> 6288"MacBook Pro" -> 8488)
    println(a.mkString("[",", ","]"))
    println("10% OFF")
    val = for( (k,v) <- a ) yield (k, v * 0.9
    println(b.mkString("[",", ","]"))
     
  }
}
/*result
[Mac Mini -> 4988, MacBook Air -> 6288, MacBook Pro -> 8488]
10% OFF
[Mac Mini -> 4489.2, MacBook Air -> 5659.2, MacBook Pro -> 7639.2]
*/

2. 编写一段程序,从文件中读取单词。用一个可变映射来清点每一个单词出现的频率。读取这些单词的操作可以使用java.util.Scanner:
val in = new java.util.Scanner(new java.io.File("myfile.txt"))
while(in.hasNext()) 处理 in.next()
或者翻到第9章看看更Scala的做法。
最后,打印出所有单词和它们出现的次数。

3. 重复前一个练习,这次用不可变的映射。
object App{
  def main(args: Array[String]){
    val map = countWord("myfile.txt")
    println(map.mkString("["", ""]"))
     
     
  }
  def countWord(filename:String)={
    var words = Map[String, Int]()
     
    val in = new java.util.Scanner(new java.io.File("myfile.txt"))
    while(in.hasNext()){
        var key = in.next()
        words += (key -> (words.getOrElse(key,0) + 1))
    }
    words
  }
   
}
/*result
 
*/

4. 重复前一个练习,这次用已排序的映射,以便单词可以按顺序打印出来。
object App{
  def main(args: Array[String]){
    val map = countWord("myfile.txt")
    println(map.mkString("["", ""]"))
     
     
  }
  def countWord(filename:String)={
    var words = scala.collection.immutable.SortedMap[String, Int]()
     
    val in = new java.util.Scanner(new java.io.File("myfile.txt"))
    while(in.hasNext()){
        var key = in.next()
        words += (key -> (words.getOrElse(key,0) + 1))
    }
    words
  }
   
}
/*result
 
*/

5. 重复前一个练习,这次用java.util.TreeMap并使之适用于Scala API

import scala.collection.JavaConversions.mapAsScalaMap
object App{
  def main(args: Array[String]){
    val map = countWord("myfile.txt")
    println(map.mkString("["", ""]"))
     
     
  }
  def countWord(filename:String)={
    var words = new java.util.TreeMap[String, Int]()
     
    val in = new java.util.Scanner(new java.io.File("myfile.txt"))
    while(in.hasNext()){
        var key = in.next()
        words += (key -> (words.getOrElse(key,0) + 1))
    }
    words
  }
   
}
/*result
*/

6. 定义一个链式哈希映射,将"Monday"映射到java.util.Calendar.MONDAY,以此类推加入其他日期。
展示元素是以插入的顺序被访问的。
import scala.collection.JavaConversions.mapAsScalaMap
 
object App{
  def main(args: Array[String]){
    val map = weekday("myfile.txt")
    println(map.mkString("["", ""]"))
     
  }
  def weekday(filename:String)={
    var weekdays = new java.util.LinkedHashMap[String,Int]()
    weekdays("Monday"= java.util.Calendar.MONDAY
    weekdays("Tuesday"= java.util.Calendar.TUESDAY
    weekdays("Wednesday"= java.util.Calendar.WEDNESDAY
    weekdays("Thursday"= java.util.Calendar.THURSDAY
    weekdays("Friday"= java.util.Calendar.FRIDAY
    weekdays("Saturday"= java.util.Calendar.SATURDAY
    weekdays("Sunday"= java.util.Calendar.SUNDAY
    weekdays
  }
   
}
/*result
[Monday -> 2, Tuesday -> 3, Wednesday -> 4, Thursday -> 5, Friday -> 6, Saturday -> 7, Sunday -> 1]
*/

7.  打印出所有Java系统属性的表格,类似这样:
java.runtime.name    |  Java(TM) SE Runtime Environment
...
你需要找到最长键的长度才能正确地打印出这张表格。
import scala.collection.JavaConversions.propertiesAsScalaMap
 
object App{
  def main(args: Array[String]){
    printSystemProperties()
  }
  def printSystemProperties()={
    val props: scala.collection.Map[String, String] = System.getProperties()
    var maxlen = 0
    for((k,_) <- props) if(maxlen < k.length) maxlen = k.length
    maxlen += 1
     
    for((k,v) <- props){
        printf("%-" + maxlen.toString + "s | %s\n", k, v)
    }
  }
}
/*result
java.vm.specification.version  | 1.8
sun.java.command               | scala.tools.nsc.MainGenericRunner e4-7.scala
java.home                      | H:\ProgramFiles\Java\jdk1.8.0_25\jre
...
*/

8.  编写一个函数minmax(values: Array[Int]),返回数组中最小值和最大值的对偶。
object App{
  def main(args: Array[String]){
    val = Array(1,2,3,4,5,6,7)
    val = minmax(a)
    println(a.mkString("[",", ","]"))
    println(b)
  }
  def minmax(values: Array[Int])={
    (values.min,values.max)
  }
}
/*result
[1, 2, 3, 4, 5, 6, 7]
(1,7)
*/

9. 编写一个函数lteqgt(values: Array[Int], v: Int),返回数组中小于v、等于v和大于v的数量,要求三个值一起返回。
object App{
  def main(args: Array[String]){
    val = Array(1,2,3,4,5,6,7)
    val = lteqgt(a, 4)
    println(a.mkString("[",", ","]"))
    println(b)
  }
  def lteqgt(values: Array[Int], v: Int)={
    val lt = values.count(_ < v)
    val eq = values.count(_ == v)
    val gt = values.count(_ > v)
     
    (lt, eq, gt)
  }
}
/*result
[1, 2, 3, 4, 5, 6, 7]
(3,1,3)
*/

10. 当你将两个字符串拉链在一起,比如"Hello".zip("World"),会是什么结果?想出一个讲得通的用例。
object App{
  def main(args: Array[String]){
    val = zip("Hello""World")
    println(a)
    //println(a.mkString("[",", ","]"))
  }
  def zip(s1:String, s2:String)={
    val = s1.zip(s2)
     
    a
  }
}
/*result
Vector((H,W), (e,o), (l,r), (l,l), (o,d))
*/



Ch04 映射和元组 - 练习的更多相关文章

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

    知识点: 1.构造映射,映射是对偶的集合 val scores1 = Map("Alice" -> 10, "Bob" -> 7, "Ci ...

  2. Scala学习(四)---映射和元组

    映射和元组 摘要: 一个经典的程序员名言是:"如果只能有一种数据结构,那就用哈希表吧".哈希表或者更笼统地说映射,是最灵活多变的数据结构之一.映射是键/值对偶的集合.Scala有一个通用的叫法:元组, ...

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

    4 映射和元组  4.1 设置一个映射,当中包括你想要的一些装备,以及它们的价格.然后构建还有一个映射.採用同一组键,可是价格上打9折 映射的简单操作  ,"gun"->18 ...

  4. 【scala】 scala 映射和元组操作(四)

    1.映射  Map 定义 ,取值,遍历,排序 2. 元组 定义,取值,拉链操作 import scala.collection.mutable /** * 映射和元组 * * @author xwol ...

  5. Scala的映射和元组操作

    映射和元组操作 构造Map // 构造一个不可变的MAP映射,类似与key -> value这样的组合叫做对偶 val score = Map("Jack" -> 12 ...

  6. Scala从入门到放弃(三)Scala的数组、映射、元组和集合

    1.数组 1.1定长数组和变长数组 object ArrayDemo { def main(args: Array[String]): Unit = { //初始化一个长度为8的定长数组,其数组元素均 ...

  7. 学好Spark/Kafka必须要掌握的Scala技术点(一)变量、表达式、循环、Option、方法和函数,数组、映射、元组、集合

    前言 Scala是以JVM为运行环境的面向对象的函数式编程语言,它可以直接访问Java类库并且与Java框架进行交互操作.正如之前所介绍,Spark是用Scala语言编写的,Kafka server端 ...

  8. Scala:映射和元组

    映射是键值对偶的集合.Scala有一个通用的叫法——元组:n个对象的聚集,并不一定要相同的类型. 构造映射 键A -> 值B scala> val scores = Map()//不可变映 ...

  9. 《快学Scala》——数组、映射和元组

    数组 定长数组:在Scala中可以用Array,初始化一个定长数组.例如: val nums = new Array[Int](10) //10个整数的数组,所有元素初始化为0 val a = new ...

随机推荐

  1. [转]Go语言中的make和new

    前言 本文主要给大家介绍了Go语言中函数new与make的使用和区别,关于Go语言中new和make是内建的两个函数,主要用来创建分配类型内存.在我们定义生成变量的时候,可能会觉得有点迷惑,其实他们的 ...

  2. mac 环境变量

    在 ~/.bash_profile 中添加一行: export PATH=$PATH:/usr/local/bin 其中,/usr/local/bin 为需要添加的 path 执行 source .b ...

  3. OE1、OE2、ON1、ON2路由有什么区别?

    OSPF的路由类型: 1 .O    域内路由 2 .O/A  域间路由 3 .OE1  域外路由,会累加METRIC值(默认20) 4 .OE2  域外路由,不累加METRIC值(默认20),由外部 ...

  4. 织梦channelartlist标签当前栏目高亮

    channelartlist标签完美支持currentstyle属性,实现自动加载当前栏目CSS样式,可以用来标识当前栏目位置的CSS,解决方法如下: 打开文件include\taglib\chann ...

  5. 【MyBatis学习06】_parameter:解决There is no getter for property named in class java.lang.String

    我们知道在mybatis的映射中传参数,只能传入一个.通过#{参数名} 即可获取传入的值. Mapper接口文件: public int delete(int id) throws Exception ...

  6. css3 - 纯css实现一个轮播图

    这是我上一次的面试题.一晃两个月过去了. 从前都是拿原理骗人,把怎么实现的思路说出来. 我今天又被人问到了,才想起来真正码出来.码出来效果说明一切: 以上gif,只用到了5张图片,一个html+css ...

  7. 【消灭代办】第4周 - Echarts在移动端的各种填坑姿势

    啊呀呀呀呀...... 2018-12-03 代办一:坐标指示器相关问题: 见另一篇 第二问:https://www.cnblogs.com/padding1015/p/9936533.html 20 ...

  8. css 使元素居中

    css使元素水平居中 1.对于行内元素的水平居中 给父元素设置text-align:center <div style="text-align:center;">居中显 ...

  9. macOS Sierra上面的php开发环境安装

    本文参考资料: 启动apache时,解决  How to Fix AH00558 and AH00557 httpd apr_sockaddr_info_get() Error Message     ...

  10. 飞机躲避炮弹---java

    最近闲来无事,花了一天多的时间写了一个小游戏,虽然说游戏本身很无聊吧,但是自己也从这个过程中学到了许多东西...分享一下. 代码内容自行理解吧... 层次结构: package cn.sxt.game ...