快学Scala习题解答—第三章 数组相关操作
3 数组相关操作
3.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(","))
3.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(","))
3.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(","))
3.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
- }
val a = Array(1,3,-3,-5,-7,3,2)
def reorderArray(arr: Array[Int]) = {
val b = arr.filter(_ > 0)
val c = arr.filter(_ <= 0)
val newarr = b ++ c
print(newarr.toBuffer.toString())
}
reorderArray(a)
3.5 怎样计算Array[Double]的平均值?
- def aveArray(arr:Array[Double]):Double={
- arr.sum/arr.length
- }
3.6 怎样又一次组织Array[Int]的元素将他们以反序排列?对于ArrayBuffer[Int]你又会怎么做呢?
- def reverseArray(arr:Array[Int]):Array[Int]={
- arr.reverse
- }
3.7 编写一段代码,产出数组中的全部值。去掉反复项。
(提示:查看Scaladoc)
产出数组的代码就不编写了。去重仅仅须要调用api就可以
- def distinctArray(arr:Array[Int]):Array[Int]={
- val t = arr.toBuffer
- t.distinct.toArray
- }
3.8 又一次编写3.4节结尾的演示样例。收集负值元素的下标。反序,去掉最后一个下标。然后对每一个下标调用a.remove(i)。
比較这样做的效率和3.4节中另外两种方法的效率
def removeArray(array: Array[Int]){
val t = array.toBuffer
val index = for (i <- 0 until array.length if array(i) < 0) yield i
val right = index.reverse.dropRight(1)
right.foreach(t.remove(_))
print(t)
} val a = Array(1,3,-3,-5,-7,3,2,1)
removeArray(a)
3.9 创建一个由java.util.TimeZone.getAvailableIDs返回ide时区集合,推断条件是它们在美洲。去掉"America/"前缀并排序
val americaTimeZone = java.util.TimeZone.getAvailableIDs
val americatimezone = java.util.TimeZone.getAvailableIDs.filter(_.take(8)=="America/")
val sortedamericaTimeZone = americaTimeZone.map(_.drop(8)).sorted
3.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(" | ")
快学Scala习题解答—第三章 数组相关操作的更多相关文章
- 快学Scala习题解答—第四章 映射和元组
4 映射和元组 4.1 设置一个映射,当中包括你想要的一些装备,以及它们的价格.然后构建还有一个映射.採用同一组键,可是价格上打9折 映射的简单操作 ,"gun"->18 ...
- 快学scala习题解答--第五章 类
5 类 5.1 改进5.1节的Counter类,让它不要在Int.MaxValue时变成负数 class Count{ private var value = Int.MaxValue else v ...
- 快学Scala习题解答—第一章 基础
1 简介 近期对Scala比较感兴趣,买了本<快学Scala>,感觉不错.比<Programming Scala:Tackle Multi-Core Complexity on th ...
- 快学Scala习题解答—第十章 特质
10 特质 10.1 java.awt.Rectangle类有两个非常实用的方法translate和grow,但可惜的是像java.awt.geom.Ellipse2D这种类没有. 在Scala中,你 ...
- 《快学Scala》第三章 数组相关操作
- 快学Scala-第三章 数组相关操作
知识点: 1.定长数组 Array val nums = new Array[Int](10) //10个整数的数组,所有元素初始化为0 val a = new Array[String](10) / ...
- 《C++Primer》第五版习题答案--第三章【学习笔记】
[C++Primer]第五版[学习笔记]习题解答第三章 ps:答案是个人在学习过程中书写,可能存在错漏之处,仅作参考. 作者:cosefy Date: 2020/1/10 第三章:字符串,向量和数组 ...
- Coursera公开课Functional Programming Principles in Scala习题解答:Week 2
引言 OK.时间非常快又过去了一周.第一周有五一假期所以感觉时间绰绰有余,这周中间没有假期仅仅能靠晚上加周末的时间来消化,事实上还是有点紧张呢! 后来发现每堂课的视频还有相应的课件(Slide).字幕 ...
- 《快学Scala》
Robert Peng's Blog - https://mr-dai.github.io/ <快学Scala>Intro与第1章 - https://mr-dai.github.io/S ...
随机推荐
- Spring Data MongoDB 五:进阶文档查询(分页、Morphia)(二)
Spring Data MongoDB 三:基本文档查询(Query.BasicQuery)(一) 学习MongoDB 六: MongoDB查询(游标操作.游标信息)(三) 一.简单介绍 Spring ...
- AWR系列之中的一个——AWR简单介绍
AWR的全称是Automatic Workload Repository(自己主动负载知识库). 它是通过对照两次快照的方式收集到统计信息.来生成txt或者html页面形式的报告. 通常,通过AWR报 ...
- 连载:面向对象葵花宝典:思想、技巧与实践(30) - SRP原则
前面具体阐述了"高内聚低耦合"的整体设计原则.但怎样让设计满足这个原则,并非一件简单的事情.幸好各位前辈和大牛已经帮我们归纳总结出来了,这就是"设计原则"和&q ...
- Ubuntu输入su提示认证失败的解决方法
用su切换,输入密码提示认证失败,这下搞了吧,后来一经查阅原来Ubuntu安装后,root用户默认是被锁定了的,不允许登录,也不允许 su 到 root ,对于桌面用户来说这个可能是为了增强安全性,但 ...
- 智课雅思词汇---十三、前缀ab-是什么意思
智课雅思词汇---十三.前缀ab-是什么意思 一.总结 一句话总结:分离,脱离;相反;加强意义 前缀:ab- [词根含义]:分离,脱离;相反;加强意义 [词根来源]:来源于拉丁语前缀ab-. [同源单 ...
- Linux top命令简解
简介: top 命令是最流行的性能监视工具之一,它是一个优秀的交互式工具,用于监视性能.它提供系统整体性能,但报告进程信息才是 top 命令的长处. top 界面分为两个部份,光标上面部份显示关于系统 ...
- ZBrush中平滑笔刷介绍
平滑笔刷在ZBrush®中的使用颇多,它可以在ZBrush®模型的多层细分下工作,并且能够控制对模型的平滑效果,而且还能将模型的细节完整保留.默认情况下,按住Shift键就会切换到平滑笔刷,根据调整不 ...
- Python多线程一学就会!
免费Python课程:阿里云大学——开发者课堂 Python中使用线程有两种方式:函数或者用类来包装线程对象. 函数式:调用thread模块中的start_new_thread()函数来产生新线程.语 ...
- C# 基础复习 二 面向对象
继承:子承父业 子:子类 父:父类 业:所有非私有成员 好处:代码的复用 继承后,实例化子类时,不止子类的构造,父类的构造也会执行,而且父类的构造先于子类的构造执行 即使在子类可以看 ...
- [学习笔记] CS131 Computer Vision: Foundations and Applications:Lecture 3 线性代数初步
向量和矩阵 什么是矩阵/向量? Vectors and matrix are just collections of ordered numbers that represent something: ...