03 快学scala第三章习题答案

本文介绍Scala中数组的各种实用操作,包括生成随机数组、元素置换、排序及筛选等,并提供了具体的代码实现。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

\1. 编写一段代码,将a设置为一个n个随机整数的数组,要求随机数介于0n之间。

1

2

3

4

5

6

7

8

9

10

11

12

objectApp

{

  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

objectApp

{

  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

9

10

11

12

13

14

15

16

17

18

19

objectApp

{

  def main(args: Array[String]) {

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

    val b = revertYield(a);

    b.foreach(println);

  }

 

  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

 

objectApp

{

  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

10

11

12

objectApp

{

  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]) = {

    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

 

objectApp

{

  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

 

objectApp

{

  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)

  }

}

\8. 重新编写3.4节结尾的示例。收集负值元素的下标,反序,去掉最后一个下标,然后对每一个下标调用a.remove(i)。比较这样做的效率和3.4节中另外两种方法的效率。

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

import scala.collection.mutable.ArrayBuffer

 

objectApp

{

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

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

    val c = deleteUnFirstF(b)

    c.foreach(println)

  }

 

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

    val indexes = (for (i <- 0 until arr.length if arr(i) < 0) yield i)

    val rights  = indexes.reverse.dropRight(1)

    val tmp = arr.toBuffer

    for (index <- rights) tmp.remove(index)

    tmp

  }

}

\9. 创建一个由java.util.TimeZone.getAvailableIDs返回的时区集合,判断条件是它们在美洲,去掉”America/“前缀并排序。

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

import scala.collection.mutable.ArrayBuffer

import scala.collection.JavaConversions.asScalaBuffer

 

object App

{

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

    var c = timeZoneName()

    c.foreach(println)

  }       

 

  def timeZoneName() = {

    val arr = java.util.TimeZone.getAvailableIDs();

    val tmp = (for (i <- arr if i.startsWith("America/")) yield {

      i.drop("America/".length)

    })

    scala.util.Sorting.quickSort(tmp)

    tmp

  }

}

\10. 引入java.awt.datatransfer._并构建一个类型为SystemFlavorMap类型的对象,然后以DataFlavor.imageFlavor为参数调用getNativesForFlavor方法,以Scala缓冲保存返回值。

1

2

3

4

5

6

7

8

9

10

11

12

import scala.collection.JavaConversions.asScalaBuffer

import scala.collection.mutable.Buffer

import java.awt.datatransfer._

 

object App

{

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

     val flavors = SystemFlavorMap.getDefaultFlavorMap().asInstanceOf[SystemFlavorMap]

     val buf : Buffer[String] = flavors.getNativesForFlavor(DataFlavor.imageFlavor);

     buf.foreach(println);

  }

}

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值