快学Scala习题解答—第三章 数组相关操作
来源:互联网 发布:苏州工业园区人工智能 编辑:程序博客网 时间:2024/05/16 06:40
原文链接:http://blog.csdn.net/ivan_pig/article/details/8257365
--------------------------------------------------
4 数组相关操作
4.1 编写一段代码,将a设置为一个n个随机整数的数组,要求随机数介于0(包含)和n(不包含)之间
random和yield的使用
import scala.collection.mutable.ArrayBufferimport scala.math.randomdef randomArray(n:Int):Array[Int]={ val a = for(i <- 0 until n) yield (random * n).toInt a.toArray}
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 <- 0 until (t.length,2) if i + 1 < t.length){ val a = t(i) val b = t(i + 1) t.remove(i,2) t.insert(i,b) t.insert(i + 1,a) } t.toArray}
4.3 重复前一个练习,不过这一次生成一个新的值交换过的数组。用for/yield
def reorderArray(arr:Array[Int]):Array[Int]={ val t = arr.toBuffer val result = for(i <- 0 until t.length) yield if(i%2==0 && i + 1 < t.length)t(i + 1) else if(i%2==0 && i + 1 >= t.length)t(i) else t(i - 1) result.toArray}
感觉代码有点丑也难读。需要优化。
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 }//使用filterdef 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=461
阅读全文
0 0
- 快学Scala习题解答—第三章 数组相关操作
- 快学Scala习题解答—第三章 数组相关操作
- 快学Scala习题解答—第三章 数组相关操作
- 快学Scala习题解答—第三章 数组相关操作
- 《快学Scala》第三章习题解答
- 快学Scala习题解答—第十一章 操作符
- 快学Scala习题解答—第十一章 操作符
- 快学Scala习题解答—第十一章 操作符
- 《快学Scala》第二章习题解答
- 《快学Scala》第四章习题解答
- 《快学Scala》第五章习题解答
- 《快学Scala》第六章习题解答
- 《快学Scala》第九章习题解答
- 《快学Scala》第十三章习题解答
- 《快学Scala》第十六章习题解答
- 快学Scala习题解答—第五章 类
- 快学Scala习题解答—第六章 对象
- 快学Scala习题解答—第八章 继承
- Android性能优化
- 关于I2C锁死的解决方案
- 嵌入式项目研发流程
- SQL_oracle_将字符串分割成结果集
- |3441|n个数的排序
- 快学Scala习题解答—第三章 数组相关操作
- 1091. Acute Stroke (30)
- 架构师是如何炼成的?以天猫APP架构&开发模式升级工程为例
- Android程序中设置操作埋点,监听网页开启关闭,控件点击
- 浅谈 java中 IO流 对文件的操作
- QML 性能上的注意事项和建议
- splay讲解
- 曲率的计算和曲率图的采样
- datatables简单使用实例