4 数组相关操作
4.1 编写一段代码,将a设置为一个n个随机整数的数组,要求随机数介于0(包含)和n(不包含)之间
random和yield的使用
import scala.math.random
def randomArray(n:Int)={
for(i <- 0 until n) yield (random * n).toInt
}
println(randomArray(10).mkString(","))
4.2 编写一个循环,将整数数组中相邻的元素置换。例如,Array(1,2,3,4,5)经过置换后变为Array(2,1,4,3,5)
对数组方法的使用
def reorderArray(arr:Array[Int]):Array[Int]={
val t = arr.toBuffer
for(i <- 1 until (t.length,2);tmp = t(i);j <- i - 1 until i){
t(i) = t(j)
t(j) = tmp
}
t.toArray
}
println(reorderArray(Array(1,2,3,4,5)).mkString(","))
4.3 重复前一个练习,不过这一次生成一个新的值交换过的数组。用for/yield
def reorderArray(arr:Array[Int]):Array[Int]={
(for(i <- 0 until (arr.length,2)) yield if (i + 1 < arr.length) Array(arr(i + 1),arr(i)) else Array(arr(i))).flatten.toArray
}
println(reorderArray(Array(1,2,3,4,5)).mkString(","))
4.4 给定一个整数数组,产生一个新的数组,包含元数组中的所有正值,以原有顺序排列,之后的元素是所有零或负值,以原有顺序排列
//使用循环
def reorderArray(arr:Array[Int]):Array[Int]={
val a = ArrayBuffer[Int]()
val b = ArrayBuffer[Int]()
arr.foreach(arg => if(arg > 0) a += arg else b += arg)
a ++= b
a.toArray
}
//使用filter
def reorderArray(arr:Array[Int]):Array[Int]={
val a = arr.filter(_ > 0).map(1 * _)
val b = arr.filter(_ <= 0).map(1 * _)
val c = a.toBuffer
c ++= b
c.toArray
}
4.5 如何计算Array[Double]的平均值?
def aveArray(arr:Array[Double]):Double={
arr.sum/arr.length
}
4.6 如何重新组织Array[Int]的元素将他们以反序排列?对于ArrayBuffer[Int]你又会怎么做呢?
def reverseArray(arr:Array[Int]):Array[Int]={
arr.reverse
}
4.7 编写一段代码,产出数组中的所有值,去掉重复项。(提示:查看Scaladoc)
产出数组的代码就不编写了。去重只需要调用api即可
def distinctArray(arr:Array[Int]):Array[Int]={
val t = arr.toBuffer
t.distinct.toArray
}
4.8 重新编写3.4节结尾的示例。收集负值元素的下标,反序,去掉最后一个下标,然后对每个下标调用a.remove(i)。比较这样做的效率和3.4节中另外两种方法的效率
性能嘛,自己比较吧!
def removeArray(arr:Array[Int]):Array[Int]={
val t = arr.toBuffer
val idx = ArrayBuffer[Int]()
for(i <- 0 until t.length){
if(t(i) < 0)idx += i
}
idx.remove(0)
idx.reverse
idx.foreach(t.remove(_))
t.toArray
}
4.9 创建一个由java.util.TimeZone.getAvailableIDs返回ide时区集合,判断条件是它们在美洲。去掉"America/"前缀并排序
显示的都是中文时间,后续的过滤无法操作。只列出所有的时区
val t = for(i <- getAvailableIDs) yield
getTimeZone(i).getDisplayName()
4.10 引入java.awt.datatransfer.并构建一个类型为SystemFlavorMap类型的对象:
val flavors = SystemFlavorMap.getDefaultFlavorMap().asInstanceOf[SystemFlavorMap] 然后以DataFlavor.imageFlavor为参数调用getNativesForFlavor方法,以Scala缓冲保存返回值。 (为什么用这样一个晦涩难懂的类?因为在Java标准库中很难找到使用java.util.List的代码)
val flavors = SystemFlavorMap.getDefaultFlavorMap().asInstanceOf[SystemFlavorMap]
println(flavors.getNativesForFlavor(DataFlavor.imageFlavor).toArray.toBuffer.mkString(" | ")
Blog URL:http://www.ivanpig.com/blog/?p=46
分享到:
相关推荐
快学scala习题、答案、详细解答 快学scala第一章习题答案.doc 快学scala第二章习题答案.doc 快学scala第三章习题答案.doc ......
快学scala 完整清晰版 大数据spark 主要的编程语言 快学scala 完整清晰版 大数据spark 主要的编程语言
快学scala的习题和答案,对学习scala有巨大帮助,可以好好学习scala,在学习的过程中可以边看边练习~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
快学Scala 课后习题答案集合
快学Scala 课后习题答案集合-中文版
快学scala的最新版本,独家一份,学习spark2.0的必备入门书籍,快来下载,绝对高清
快学Scala-课后习题答案-源码-总22章;解压导入即可使用
《快学Scala》是一门以Java虚拟机(JVM)为目标运行环境并将面向对象和函数式编程语言的特性结合在一起的编程语言。你可以使用Scala编写出更加精简的程序,同时充分利用并发的威力。由于Scala运行于JVM之上,因此它...
快学Scala课后习题答案,包含各个章节答案word版和pdf版
快学scala答案总汇
花了5元订制的快学Scala pdf电子书! Scala是一门以Java虚拟机(JVM)为目标运行环境并将面向对象和函数式编程语言的最佳特性结合在一起的编程语言。你可以使用Scala编写出更加精简的程序,同时充分利用并发的威力...
快学scala中文版带目录,清晰 快学scala中文版带目录,清晰 快学scala中文版带目录,清晰 快学scala中文版带目录,清晰 快学scala中文版带目录,清晰 快学scala中文版带目录,清晰 快学scala中文版带目录,清晰
快学Scala 中文版带目录 快学Scala 中文版带目录1 快学Scala 中文版带目录2
第3章 数组相关操作 A1 39 3.1 定长数组 39 3.2 变长数组:数组缓冲 40 3.3 遍历数组和数组缓冲 41 3.4 数组转换 42 3.5 常用算法 44 3.6 解读Scaladoc 45 3.7 多维数组 47 3.8 与Java的互操作 48 练习 49 ...
Cay S.Horstmann所著的《快学Scala》内容简介:Scala是一门以Java 虚拟机(JVM)为目标运行环境并将面向对象和函数式编程语言的**特性结合在一起的编程语言。你可以使用Scala编写出更加精简的程序,同时充分利用并发...
Scala-快学Scala 中文版, 一本scala入门的经典书籍, 推荐!
Scala for the Impatient 中文版 快学Scala pdf(含目录) scala 快速入门书箱 scala经典图书 Core Java作者最新力作 中文版 快学Scala Scala for the Impatient 中文版 [美]C S 霍斯曼 2012 电子工业出版社
随着大数据上升为国家战略,现在各大公司都开始进军大数据行业。...《快学Scala》的作者是国际畅销书《Java核心技术》的主要作者,作者基于完全实用的角度给出了学习Scala的快速、基于代码的入门指南!
scala入门书籍,快学scala,简单概述scala的基本内容,完整中文版