首页 > 其他分享 >无涯教程-Scala - 数组(Arrays)

无涯教程-Scala - 数组(Arrays)

时间:2024-01-26 13:32:27浏览次数:29  
标签:Scala Arrays Demo scala 无涯 Int 数组 Array def

Scala提供了一种数据结构数组 ,它存储了相同类型元素的固定大小的顺序集合。

声明数组

要在程序中使用数组,必须声明一个变量以引用该数组,并且必须指定该变量可以引用的数组的类型。

var z:Array[String]=new Array[String](3)

or

var z=new Array[String](3)

在此,z被声明为可容纳最多三个元素的字符串数组。可以将值分配给单个元素或访问单个元素,这可以通过使用以下命令来完成:

z(0)="Zara"; z(1)="Nuha"; z(4/2)="Ayan"

在这里,最后一个示例表明,索引通常可以是产生整数的任何表达式。还有一种定义数组的方法-

var z=Array("Zara", "Nuha", "Ayan")

下图表示一个数组 myList 。在这里, myList 拥有十个双精度值,索引从0到9。

Scala Array

处理数组

在处理数组元素时,我们经常使用循环控制结构,因为数组中的所有元素都是相同的类型,并且数组的大小是已知的。

object Demo {
   def main(args: Array[String]) {
      var myList=Array(1.9, 2.9, 3.4, 3.5)
      
      //打印所有数组元素
      for ( x <- myList ) {
         println( x )
      }

      //对所有元素求和
      var total=0.0;
      
      for ( i <- 0 to (myList.length - 1)) {
         total += myList(i);
      }
      println("Total is " + total);

      //找到最大的元素
      var max=myList(0);
      
      for ( i <- 1 to (myList.length - 1) ) {
         if (myList(i) > max) max=myList(i);
      }
      
      println("Max is " + max);
   }
}

将上述程序保存在 Demo.scala 中。以下命令用于编译和执行该程序。

\>scalac Demo.scala
\>scala Demo
1.9
2.9
3.4
3.5
Total is 11.7
Max is 3.5

多维数组

在许多情况下,您需要定义和使用多维数组(即,其元素为数组的数组)。如,矩阵和表格是可以实现为二维数组的结构的示例。

var myMatrix=ofDim[Int](3,3)

这是一个具有三个元素的数组,每个元素都是具有三个元素的整数数组。

import Array._

object Demo {
   def main(args: Array[String]) {
      var myMatrix=ofDim[Int](3,3)
      
      //建立一个矩阵
      for (i <- 0 to 2) {
         for ( j <- 0 to 2) {
            myMatrix(i)(j)=j;
         }
      }
      
      //打印二维数组
      for (i <- 0 to 2) {
         for ( j <- 0 to 2) {
            print(" " + myMatrix(i)(j));
         }
         println();
      }
   }
}

将上述程序保存在 Demo.scala 中。以下命令用于编译和执行该程序。

\>scalac Demo.scala
\>scala Demo
0 1 2
0 1 2
0 1 2

合并数组

请尝试以下示例,该示例利用concat()方法来连接两个数组,您可以将多个数组作为参数传递给concat()方法。

import Array._

object Demo {
   def main(args: Array[String]) {
      var myList1=Array(1.9, 2.9, 3.4, 3.5)
      var myList2=Array(8.9, 7.9, 0.4, 1.5)

      var myList3= concat( myList1, myList2)
      
      //打印所有数组元素
      for ( x <- myList3 ) {
         println( x )
      }
   }
}

将上述程序保存在 Demo.scala 中。以下命令用于编译和执行该程序。

\>scalac Demo.scala
\>scala Demo
1.9
2.9
3.4
3.5
8.9
7.9
0.4
1.5

Range创建数组

使用range()方法生成一个数组,该数组包含给定范围内的递增整数序列。您可以使用final参数作为创建序列的步骤,step默认为1。

让我们以创建范围为(10,20,2)的数组为例:这意味着创建一个数组,其元素之间的差值为10到20,步长为2。该数组中的元素为10、12、14、16和18。 

import Array._

object Demo {
   def main(args: Array[String]) {
      var myList1=range(10, 20, 2)
      var myList2=range(10,20)

      //打印所有数组元素
      for ( x <- myList1 ) {
         print( " " + x )
      }
      
      println()
      for ( x <- myList2 ) {
         print( " " + x )
      }
   }
}

将上述程序保存在 Demo.scala 中。以下命令用于编译和执行该程序。

\>scalac Demo.scala
\>scala Demo
10 12 14 16 18
10 11 12 13 14 15 16 17 18 19

数组方法

以下是重要的方法,您可以在使用数组时使用它们,如上所示,在使用任何上述方法之前,您必须导入 Array ._ 包。有关可用方法的完整列表,请查看Scala的官方文档。

Sr.No Methods with 描述
1

def apply(x:T,xs:T *):Array[T]

创建一个T对象数组,其中T可以是Unit,Double,Float,Long,Int,Char,Short,Byte,Boolean。

2

def concat [T](xss:Array [T] *):Array [T]

将所有数组连接成一个数组。

3

def copy(src:AnyRef,srcPos:Int,dest:AnyRef,destPos:Int,length:Int):Unit

将一个数组复制到另一个数组。等效于Java的System.arraycopy(src,srcPos,dest,destPos,length)。

4

def empty [T]:Array[T]

返回长度为0的数组

5

def iterate[T]( start: T, len: Int )( f: (T) => T ): Array[T]

返回一个数组,其中包含将函数重复应用到起始值的情况。

6

def fill[T]( n: Int )(elem: => T): Array[T]

返回一个数组,该数组包含多次元素计算的输出。

7

def fill[T]( n1: Int, n2: Int )( elem: => T ): Array[Array[T]]

返回一个二维数组,该数组包含多次元素计算的输出。

8

def iterate[T]( start: T, len: Int)( f: (T) => T ): Array[T]

返回一个数组,其中包含将函数重复应用到起始值的情况。

9

def ofDim [T](n1:Int):Array[T]

创建具有给定尺寸的数组。

10

def ofDim [T](n1:Int,n2:Int):Array [Array [T]]

创建一个二维数组

11

def ofDim [T](n1:Int,n2:Int,n3:Int):Array [Array [Array [Array [T]]]

创建一个三维数组

12

def range(start:Int,end:Int,step:Int):Array [Int]

返回一个数组,该数组包含以某个整数间隔的相等间隔的值。

13

def range(start:Int,end:Int):Array [Int]

返回一个数组,其中包含一个范围内递增整数的序列。

14

def tabulate[T]( n: Int )(f: (Int)=> T): Array[T]

返回一个数组,该数组包含给定函数的值,这些值在从0开始的整数值范围内。

15

def tabulate[T]( n1: Int, n2: Int )( f: (Int, Int ) => T): Array[Array[T]]

返回一个二维数组,该数组包含给定函数的值,这些值在从0开始的整数值范围内。

参考链接

https://www.learnfk.com/scala/scala-arrays.html

标签:Scala,Arrays,Demo,scala,无涯,Int,数组,Array,def
From: https://blog.51cto.com/u_14033984/9429242

相关文章

  • 无涯教程-Scala - 闭包
    closure闭包是一个函数,其返回值取决于在此函数外部声明的一个或多个变量的值。以下带有匿名函数的代码。valmultiplier=(i:Int)=>i*10这里,函数体中使用的唯一变量i*10是i,它被定义为函数的参数,尝试以下代码-valmultiplier=(i:Int)=>i*factor乘数中有两个自由变......
  • 无涯教程-Scala - 函数声明
    函数是执行任务的一组语句,您可以将代码分成单独的函数,从逻辑上讲,划分通常是使每个函数执行特定任务。函数声明Scala函数声明具有以下形式-deffunctionName([listofparameters]):[returntype]如果您不使用等号和方法主体,则方法被隐式声明为抽象。函数定义Scala函数定......
  • 无涯教程-Scala - 环境设置
    Scala可以安装在任何基于UNIX或Windows的系统上,在机器上开始安装Scala之前,必须在计算机上安装Java1.8或更高版本。请按照下面给出的步骤安装Scala。步骤1-验证Java安装首先,您需要在系统上安装Java软件开发套件(SDK)。要验证这一点,请根据所使用的平台执行以下两个命令中的任......
  • 无涯教程-Rust - 并发(Concurrency)
    在并发编程中,程序的不同部分独立执行,另一方面,在并行编程中,程序的不同部分会同时执行。线程数我们可以使用线程同时运行代码,在当前的操作系统中,已执行程序的代码在一个进程中运行,并且操作系统一次管理多个进程,在您的程序中,您还可以具有可以同时运行的独立部分,运行这些独立部分的......
  • 无涯教程-Rust - 智能指针
    Rust默认情况下在堆栈上分配所有内容,您可以通过将它们包装在智能指针(如Box)中来将它们存储在堆上,智能指针实现下表中列出的特征-Sr.NoTraitnamePackage&描述1Derefstd::ops::Deref用于不可变的取消引用操作,如*v。2Dropstd::ops::Drop当值超出范围时用于......
  • 无涯教程-Rust - 迭代&闭包
    在本章中,我们将学习RUST中的迭代器和闭包如何工作。Iterator迭代器迭代器有助于迭代值的集合,例如数组,向量,Map映射等,迭代器实现Rust标准库中定义的Iteratortrait,iter()方法返回集合的迭代器对象,迭代器对象中的值称为元素,迭代器的next()方法可用于遍历元素,当到达集合末尾时,next......
  • 无涯教程-Rust - 文件输入&输出
    除了对控制台进行读写之外,Rust还允许对文件进行读写,File结构代表一个文件,它允许程序对文件执行读写操作,File结构中的所有方法均返回io::Result枚举的变体。写入文件以下程序创建文件"data.txt",create()方法用于创建文件,如果文件创建成功,该方法将返回文件句柄,最后一行write_a......
  • 无涯教程-Rust - 输入&输出
    本章讨论如何接受来自标准输入Input的值以及如何将值显示到标准输出Output,在本章中,我们还将讨论传递命令行参数。读和写Rust的input和output标准库函数围绕两个特征进行组织-Read读Write写Sr.NoTrait&描述Example1Read- 实现Read的类型具有面向字节输入的方法。S......
  • 无涯教程-Rust - 错误处理
    在Rust中,错误可以分为两大类,如下表所示。Name&描述UsageRecoverable可恢复的错误ResultenumUnRecoverable无法恢复的错误panicmacro与其他编程语言不同,Rust没有Exception异常,它返回可恢复错误的枚举Result<T,E>,如果程序遇到不可恢复的错误,则调用panic宏。Panic......
  • 无涯教程-Rust - 元组(Tuple)
    元组是复合数据类型,标量类型只能存储一种类型的数据,如一个i32变量只能存储一个整数值。在复合类型中,我们可以存储多个值,并且可以是不同类型。元组的长度是固定的,一旦声明,它们就无法增长或缩小,元组索引从0开始。Tuple-语法//语法1lettuple_name:(data_type1,data_type2,d......