03 快学scala第三章习题答案

    xiaoxiao2025-05-04  7

    \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);

      }

    }

     

    转载请注明原文地址: https://ju.6miu.com/read-1298735.html
    最新回复(0)