3 数组相关操作 

3.1 编写一段代码。将a设置为一个n个随机整数的数组,要求随机数介于0(包括)和n(不包括)之间 

random和yield的使用

  1. import scala.math.random
  2. def randomArray(n:Int)={
  3. for(i <- 0 until n) yield (random * n).toInt
  4. }
  5. println(randomArray(10).mkString(","))

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

对数组方法的使用

  1. def reorderArray(arr:Array[Int]):Array[Int]={
  2. val t = arr.toBuffer
  3. for(i <- 1 until (t.length,2);tmp = t(i);j <- i - 1 until i){
  4. t(i) = t(j)
  5. t(j) = tmp
  6. }
  7. t.toArray
  8. }
  9. println(reorderArray(Array(1,2,3,4,5)).mkString(","))

3.3 反复前一个练习,只是这一次生成一个新的值交换过的数组。用for/yield

  1. def reorderArray(arr:Array[Int]):Array[Int]={
  2. (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
  3. }
  4. println(reorderArray(Array(1,2,3,4,5)).mkString(","))

3.4 给定一个整数数组,产生一个新的数组,包括元数组中的全部正值,以原有顺序排列,之后的元素是全部零或负值。以原有顺序排列

  1. //使用循环
  2. def reorderArray(arr:Array[Int]):Array[Int]={
  3. val a = ArrayBuffer[Int]()
  4. val b = ArrayBuffer[Int]()
  5. arr.foreach(arg => if(arg > 0) a += arg else b += arg)
  6. a ++= b
  7. a.toArray
  8. }
    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]的平均值?

  1. def aveArray(arr:Array[Double]):Double={
  2. arr.sum/arr.length
  3. }

3.6 怎样又一次组织Array[Int]的元素将他们以反序排列?对于ArrayBuffer[Int]你又会怎么做呢?

  1. def reverseArray(arr:Array[Int]):Array[Int]={
  2. arr.reverse
  3. }

3.7 编写一段代码,产出数组中的全部值。去掉反复项。

(提示:查看Scaladoc) 

产出数组的代码就不编写了。去重仅仅须要调用api就可以

  1. def distinctArray(arr:Array[Int]):Array[Int]={
  2. val t = arr.toBuffer
  3. t.distinct.toArray
  4. }

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的代码)

  1. val flavors = SystemFlavorMap.getDefaultFlavorMap().asInstanceOf[SystemFlavorMap]
  2. println(flavors.getNativesForFlavor(DataFlavor.imageFlavor).toArray.toBuffer.mkString(" | ")

快学Scala习题解答—第三章 数组相关操作的更多相关文章

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

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

  2. 快学scala习题解答--第五章 类

    5 类  5.1 改进5.1节的Counter类,让它不要在Int.MaxValue时变成负数 class Count{ private var value = Int.MaxValue else v ...

  3. 快学Scala习题解答—第一章 基础

    1 简介 近期对Scala比较感兴趣,买了本<快学Scala>,感觉不错.比<Programming Scala:Tackle Multi-Core Complexity on th ...

  4. 快学Scala习题解答—第十章 特质

    10 特质 10.1 java.awt.Rectangle类有两个非常实用的方法translate和grow,但可惜的是像java.awt.geom.Ellipse2D这种类没有. 在Scala中,你 ...

  5. 《快学Scala》第三章 数组相关操作

  6. 快学Scala-第三章 数组相关操作

    知识点: 1.定长数组 Array val nums = new Array[Int](10) //10个整数的数组,所有元素初始化为0 val a = new Array[String](10) / ...

  7. 《C++Primer》第五版习题答案--第三章【学习笔记】

    [C++Primer]第五版[学习笔记]习题解答第三章 ps:答案是个人在学习过程中书写,可能存在错漏之处,仅作参考. 作者:cosefy Date: 2020/1/10 第三章:字符串,向量和数组 ...

  8. Coursera公开课Functional Programming Principles in Scala习题解答:Week 2

    引言 OK.时间非常快又过去了一周.第一周有五一假期所以感觉时间绰绰有余,这周中间没有假期仅仅能靠晚上加周末的时间来消化,事实上还是有点紧张呢! 后来发现每堂课的视频还有相应的课件(Slide).字幕 ...

  9. 《快学Scala》

    Robert Peng's Blog - https://mr-dai.github.io/ <快学Scala>Intro与第1章 - https://mr-dai.github.io/S ...

随机推荐

  1. ContextMenu的使用具体解释

    二话不说,先上图: 能够非常easy看到这是一个类似于Dialog悬浮在活动上的控件,它是由被注冊的view长按所触发的. 当然啦,也有其它的实现方式,这里就先介绍一下系统的ContextMenu:( ...

  2. SVN各种异常解决整理

    错误1:工作副本已锁定 由于周末公司server停机维护,今天在用SVN提交业务时,直接报错: 同一时候给了解决的方法:请运行清理命令 直接返回上级文件夹单击右键.运行清除命令后,再次提交! OK! ...

  3. 赵雅智_android获取本机运营商,手机号部分能获取

    手机号码不是全部的都能获取.仅仅是有一部分能够拿到. 这个是因为移动运营商没有把手机号码的数据写入到sim卡中.SIM卡仅仅有唯一的编号.供网络与设备 识别那就是IMSI号码,手机的信号也能够说是通过 ...

  4. [jzoj 5662] 尺树寸泓 解题报告 (线段树+中序遍历)

    interlinkage: https://jzoj.net/senior/#contest/show/2703/1 description: solution: 发现$dfs$序不好维护 注意到这是 ...

  5. Spark RDD概念学习系列之action操作

    不多说,直接上干货! action操作  

  6. Centos7 minimal 系列之Redis(五)

    一.Redis安装 1.1 .进入/usr/local 创建redis文件夹(mkdir)方便统一管理 1.2.下载redis $ wget http://download.redis.io/rele ...

  7. zeromq-4.1.2在windows下的编译

    作者:朱金灿 来源:http://blog.csdn.net/clever101 zeromq是一个最近比较火的跨平台消息中间件,最近准备研究它,故下载它的源码编译了一下.我是使用VS2008编译的, ...

  8. Android 中的View与ViewGroup

    Android重点知识--View和ViewGroup与自定义控件 作者:丁明祥 邮箱:2780087178@qq.com 一.基础 ViewGroup 参考资料: Android 手把手教您自定义V ...

  9. linux拷贝文件

    linux之cp/scp命令+scp命令详解 2011-03-09 17:27:22|  分类: Linux |  标签:linux  cp  scp  commond   |字号 订阅   名称:c ...

  10. github踩坑之git命令收集与整理(windows)

    最近开始又捡起git,第一家公司用的就是git,一直掌握的也不深刻,就知道常用的几个命令,虽然现在用svn,但是觉得git还是不能丢,遂又捡起来了.先总结一部分目前练习用到的,慢慢填补吧~ githu ...