且听书吟

  • 首页
  • 关于
  • 留言
  • 友链
  • 笔记
  • 代码
且听书吟

A scala exercise a day 1

2016-11-16

mocha ドラム水槽

1、编写一段代码,将 a 设置为一个 n 个随机整数的数组,要求随机数介于 [0, n) 之间。

def randomArray(n: Int) : Array[Int] = {
  (for (i <- 0 until n) yield (math.random * n).toInt).toArray
}

2、编写一个循环,将整数数组中相邻的元素置换。例如,Array(1, 2, 3, 4, 5) 经过置换之后变为 Array(2, 1, 4, 3, 5)。

def transferArray(array: Array[Int]) : Array[Int] = {
  for (i <- array.indices if i % 2 == 1) {
    val temp = array(i)
    array(i) = array(i - 1)
    array(i - 1) = temp
  }
  array
}

3、重复前一个练习,不过这次生成一个新的值交换过的数组。用 for/yield。

def transferArray(array: Array[Int]) : Array[Int] = {
  (for (i <- array.indices) yield {
    i % 2 match {
      case 1 => array(i - 1)
      case 0 => if (i + 1 == array.length) array(i) else array(i + 1)
    }
  }).toArray
}

4、给定一个整数数组,产出一个新的数组,包含元素组中的所有正值,以原有顺序排列,之后的元素是所有的零或负值,以原有顺序排列。

def sortArray(array: Array[Int]) : Array[Int] = {
  val (left, right) = array.partition(_ > 0)
  left ++ right
}

5、如何计算 Array[Double]的平均值?

def arrayAverage(array: Array[Double]) : Double = {
  array.sum / array.length
}

6、如何重新组织 Array[Int] 的元素将它们以反序排列?对于 ArrayBuffer[Int] 你又会怎么做呢?

def reverseAverage(array: Array[Int]) : Array[Int] = {
  for (i <- array.indices if i < array.length / 2) {
    val temp = array(i)
    array(i) = array(array.length - i - 1)
    array(array.length - i - 1) = temp
  }
  array
}

对于 ArrayBuffer 如下

def reverseAverage(array: ArrayBuffer[Int]) : ArrayBuffer[Int] = {
  array.reverse
}

7、编写一段代码,产出数组中的所有值,去掉重复项。

def distinctAverage(array: Array[Int]) : Array[Int] = {
  array.distinct
}

8、创建一个由 java.util.TimeZone.getAvailableIDs返回的时区集合,判断条件是它们在美洲。去掉"America/"前缀并排序。

val sortedAmericanZone = java.util.TimeZone.getAvailableIDs.filter(_.startsWith("America")).map(_.replaceFirst("America/", "")).sorted

9、引入 java.awt.datatransfer._ 并构建一个类型为 SystemFlavorMap 类型的对象: val flavors = SystemFlavorMap.getDefaultFlavorMap().asInstanceOf[SystemFlavorMap] 然后以 DataFlavor.imageFlavor 为参数调用 getNativesForFlavor 方法,以 Scala 缓冲保存返回值。

首先导入包

import java.awt.datatransfer._
import scala.collection.JavaConversions._
import scala.collection.mutable.Buffer

然后编码

val flavors = SystemFlavorMap.getDefaultFlavorMap().asInstanceOf[SystemFlavorMap]
val flavor: Buffer[String] = flavors.getNativesForFlavor(DataFlavor.imageFlavor)
0
评论 (0)
再想想
随机文章
  • 放慢,快乐
  • 相视一笑,莫逆于心
  • 灰色头像
  • 皓魄当空宝镜升,云间仙籁寂无声。
  • 我们的时代——《小时代》读后感
  • 写在今天——记重开始写博
近期评论
  • 咚门发表在《中年的世界》
  • 云心怀鹤发表在《好羡慕,你还是学生》
  • I'M代代付发表在《写给十年后的自己》
  • 肉松发表在《写给十年后的自己》
  • 大雁养老发表在《写给十年后的自己》
  • rfed发表在《中年的世界》
文章标签
人生 同人 回忆 小说 影评 思考 悠久之翼 情感 成长 文字 时光 未来 杂思 梦想 爱情 童年 记忆 随想 青春 高考
订阅博客
Copyright © 2011-2023 且听书吟. Designed by nicetheme.
萌ICP备 20200318号