「大数据」(八十八)Scala之数组

【导读:数据是二十一世纪的石油,蕴含巨大价值,这是·情报通·大数据技术系列第[88]篇文章,欢迎阅读和收藏】

1 基本概念

Scala 语言中提供的数组是用来存储固定大小的同类型元素,数组对于每一门编程语言来说都是重要的数据结构之一。

声明数组变量并不是声明 number0 、 number1 、 ... 、 number99 一个个单独的变量,而是声明一个就像 numbers 这样的变量,然后使用 numbers[0] 、 numbers[1] 、 ... 、 numbers[99] 来表示一个个单独的变量。数组中某个指定的元素是通过索引来访问的。

数组的第一个元素索引为 0 ,最后一个元素的索引为元素总数减 1 。

2 术语解释

数组是一种用来存储固定大小的同类型元素的数据结构。

3 详细说明

以下是 Scala 数组声明的语法格式:

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

var z = new Array[String](3)

以上语法中, z 声明一个字符串类型的数组,数组长度为 3 ,可存储 3 个元素。我们可以为每个元素设置值,并通过索引来访问每个元素,如下所示:

「大数据」(八十八)Scala之数组

z(0) = "Runoob"; z(1) = "Baidu"; z(4/2) = "Google"

最后一个元素的索引使用了表达式 4/2 作为索引,类似于 z(2) = "Google" 。

我们也可以使用以下方式来定义一个数组:

var z = Array("Runoob", "Baidu", "Google")

下图展示了一个长度为 10 的数组 myList ,索引值为 0 到 9 :

3.2 处理数组

数组的元素类型和数组的大小都是确定的,所以当处理数组元素时候,我们通常使用基本的 for 循环。

以下实例演示了数组的创建,初始化等处理过程:

<code>object Test {

def main(args: Array[String]) {

var myList = Array(1.9, 2.9, 3.4, 3.5)

// 输出所有数组元素

for ( x
\t\t\t\tprintln( x )
}

// 计算数组所有元素的总和

var total = 0.0;


for ( i
\t\t\t\ttotal += myList(i);
}

println(" 总和为 " + total);

// 查找数组中的最大元素

var max = myList(0);

for ( i
\t\t\t\t\tif (myList(i) > max) max = myList(i);
}

\t\t\t\tprintln(" 最大值为 " + max);

}
}/<code>


执行以上代码,输出结果为:

<code>$ scalac Test.scala

$ scala Test

1.9

2.9

3.4

3.5

总和为 11.7

最大值为 3.5/<code>

3.3 多维数组

多维数组一个数组中的值可以是另一个数组,另一个数组的值也可以是一个数组。矩阵与表格是我们常见的二维数组。

以上是一个定义了二维数组的实例:

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

实例中数组中包含三个数组元素,每个数组元素又含有三个值。

接下来看一个二维数组处理的完整实例:

<code>import Array._

object Test {

def main(args: Array[String]) {

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

// 创建矩阵

for (i
for ( j
myMatrix(i)(j) = j;

}
}

// 打印二维阵列

for (i
for ( j
\t\t\t\tprint(" " + myMatrix(i)(j));

}

\t \t\t\t\tprintln();
}
}
}/<code>

运行实例 »

执行以上代码,输出结果为:

<code>$ scalac Test.scala

$ scala Test

0 1 2

0 1 2

0 1 2/<code>


分享到:


相關文章: