快学scala第三章习题答案

  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

\1. 编写一段代码,将a 设置为一个n 个随机整数的数组,要求随机数介于0和n 之间。 1 2 3 4 5 6 7 8 9 10 11 12 object App

{

def main(args: Array[String]) {

makeArr(10).foreach(println);

}

def makeArr(n : Int) : Array[Int] = {

val a = new Array[Int](n);

val rand = new scala.util.Random();

for (i <- a) yield rand.nextInt(n);

}

}

\2. 编写一个循环,将整数数组中相邻的元素置换。 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 object App

{

def main(args: Array[String]) {

val a = Array(1, 2, 3, 4, 5); revert(a);

a.foreach(println);

}

def revert(arr : Array[Int]) = {

for (i <- 0 until (arr.length - 1, 2)) {

val t = arr(i);

arr(i) = arr(i + 1);

arr(i + 1) = t;

}

}

}

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

1 2 3 4 5 6 7 8 object App

{

def main(args: Array[String]) {

val a = Array(1, 2, 3, 4, 5);

val b = revertYield(a);

b.foreach(println);

}

9 10 11 12 13 14 15 16 17 18 19 def revertYield(arr : Array[Int]) = {

for (i <- 0 until arr.length) yield {

if (i < (arr.length - 1) && i % 2 == 0) {

val t = arr(i);

arr(i) = arr(i + 1);

arr(i + 1) = t;

}

arr(i);

}

}

}

\4. 给定一个整数数组,产出一个新的数组,包含元数组中的所有正值,以原有顺序排列,之后的元素是所有零或负值,以原有顺序排列。 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 import scala.collection.mutable.ArrayBuffer

object App

{

def main(args: Array[String]) {

val a = Array(1, -2, 0, -3, 0, 4, 5);

val b = sigNumArr(a);

b.foreach(println);

}

def sigNumArr(arr : Array[Int]) = {

val buf = new ArrayBuffer[Int]();

buf ++= (for (i <- arr if i > 0) yield i)

buf ++= (for (i <- arr if i == 0) yield i)

buf ++= (for (i <- arr if i < 0) yield i)

buf.toArray

}

}

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

1 2 3 4 5 6 7 8 9 object App

{

def main(args: Array[String]) = {

val a = Array(1.0, -2.0, 0.0, -3.0, 0.0, 4.0, 5.0);

val b = avgArr(a);

println(b)

}

def avgArr(arr : Array[Double]) = {

10 11 12 arr.sum / arr.length

}

}

\6. 如何重新组织Array[Int]的元素将它们反序排列?对于ArrayBuffer[Int]你又会怎么做呢? 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 import scala.collection.mutable.ArrayBuffer

object App

{

def main(args: Array[String]) = {

val a = Array(1, -2, 0, -3, 0, 4, 5);

revertArray(a);

a.foreach(println)

// ArrayBuffer 反转

val b = ArrayBuffer(1, -2, 0, -3, 0, 4, 5);

val c = ArrayBuffer[Int]()

c ++= b.reverse

c.foreach(println)

}

def revertArray(arr : Array[Int]) = {

for (i <- 0 until (arr.length % 2)) {

val t = arr(i);

arr(i) = arr(arr.length - 1 - i);

arr(arr.length - 1 - i) = t;

}

}

}

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

1 2 3 4 5 6 7 8 9 10 11 12 import scala.collection.mutable.ArrayBuffer

object App

{

def main(args: Array[String]) = {

// ArrayBuffer 排重

val b = ArrayBuffer(1, -2, 0, -3, 0, 4, 5);

val c = ArrayBuffer[Int]()

c ++= b.distinct

c.foreach(println)

}

}

相关文档
最新文档