数组

数组的两种声明方式,建议声明数组时指定类型。

访问数组元素时获取数组下标

数组Array类本身有很多非常方便的方法

变长数组ArrayBuffer,能够动态增加元素,也可以实现与Array的互转

看代码:

 import scala.collection.mutable.ArrayBuffer
import java.util.ArrayList /**
* 数组
* @author Administrator
*/
object TestScalaArray {
def main(args: Array[String]) = {
//定义方式一
var arr1 = new Array[Int](3) //中括号表示数组的类型,小括号中指定是数组的长度
arr1(1) = 4 //给数组第二个元素复制为4
for(i <- arr1){
println(i)
}
/*
* 输出结果
* 0
* 4
* 0
*/ //定义方式二
var arr2 = Array(1,2,3,4,5,6,"hehe") //中括号表示数组的类型,小括号中指定是数组初始化的值
for(i <- arr2){
println(i)//循环遍历输出arr2中的值
} var arr3 = Array(1,2,3,4,5,6)
println(arr3.min)//输出数组中最小值1
println(arr3.max)//输出数组中最小值6
println(arr3.sum)//输出数组中的和
println(arr2.mkString(",")) //和Java中的Arrays.toString(arr)一样
//输出:1,2,3,4,5,6,hehe
println(arr2.mkString("[",",","]"))//这个也和Java中的Arrays.toString(arr)
//输出:[1,2,3,4,5,6,hehe] var arr4 = Array(1,2,3,4,5,6)
for(i <- 0 to arr4.length - 1){//for(i <- 0 until arr4.length - 1)
println(arr4(i))
} //利用for的推导式产生一个新的数组
var arr5 = for(i <- arr4) yield i + 1
println(arr5.mkString(","))//输出:2,3,4,5,6,7 var arr6 = Array("dbd","sdfs","yeres","bc")
println(arr6.min)//输出:bc 按照字典排序
println(arr6.max)//输出:yeres var arr7 = Array(1,5,8,2,4)
var arr8 = arr7.sorted //排序 升序
var arr9 = arr6.sorted //排序 升序 按照字典排序
println(arr8.mkString(",")) //输出: 1,2,4,5,8
println(arr9.mkString(",")) //输出: bc,dbd,sdfs,yeres //如果没有变量去接受arr7.sorted
arr7.sorted
println(arr7.mkString(",")) //输出的还是 1,5,8,2,4
//sorted并不会对原数组进行重新排序...必须有一个变量去接收排序的数组. /*变长数组*/
var arr10 = ArrayBuffer(1,2,3,4,5)//用ArrayBuffer来声明变长数组
arr10 += 9 //给一个变长数组增加一个元素用"+="
var arr11 = arr7.toBuffer //把一个定长数组arr7变成变长数组用toBuffer
arr11 ++= arr10 //给一个变长数组增加另一个数组中的元素用"++="
println(arr11.mkString(","))//输出:1,5,8,2,4,1,2,3,4,5,9 //scala的IO这块很多都没有自己封装的API,可以用Java的API
var list = new ArrayList[Int](3)
list.add(100)
list.add(101)
list.add(102) for(i <- 0 until list.size()){
println(list.get(i))// 循环遍历list数组.
}
}
}

Scala中的数组的更多相关文章

  1. 2. scala中的数组

    一. 数组声明 定长数组 scala> new Array[String](5) res1: Array[String] = Array(null, null, null, null, null ...

  2. 【Scala篇】--Scala中集合数组,list,set,map,元祖

    一.前述 Scala在常用的集合的类别有数组,List,Set,Map,元祖. 二.具体实现 数组   1.创建数组 new Array[Int](10) 赋值:arr(0) = xxx Array[ ...

  3. Scala中的数组和集合操作

    package test /* 1.在scala集合中,Iterable是共同的Trait,Iterable要求继承者实现一些共同的方法,例如元素的遍历 * 2.Array是scala基础的数据结构, ...

  4. scala中的数组的转换操作

    1.共有两种操作 转换成一种新的数组 2.yield转换 3.函数式编程转换

  5. Programming In Scala笔记-第十七章、Scala中的集合类型

    本章主要介绍Scala中的集合类型,主要包括:Array, ListBuffer, Arraybuffer, Set, Map和Tuple. 一.序列 序列类型的对象中包含多个按顺序排列好的元素,可以 ...

  6. Scala学习(三)----数组相关操作

    数组相关操作 摘要: 本篇主要学习如何在Scala中操作数组.Java和C++程序员通常会选用数组或近似的结构(比如数组列表或向量)来收集一组元素.在Scala中,我们的选择更多,不过现在我们先假定不 ...

  7. Scala中Zip相关的函数

    在Scala中存在好几个Zip相关的函数,比如zip,zipAll,zipped 以及zipWithIndex等等.我们在代码中也经常看到这样的函数,这篇文章主要介绍一下这些函数的区别以及使用. 1. ...

  8. [原创]Scala学习:数组的基本操作,数组进阶操作,多维数组

    1.Scala中提供了一种数据结构-数组,其中存储相同类型的元素的固定大小的连续集合.数组用于存储数据的集合,但它往往是更加有用认为数组作为相同类型的变量的集合 2 声明数组变量: 要使用的程序的数组 ...

  9. Scala中的If判断&While&For循环

    If 判断: object TestScalaIf { def main(args: Array[String]): Unit = { // val resutlt = judge1(-100) // ...

随机推荐

  1. MLlib 中的聚类和分类

    聚类和分类是机器学习中两个常用的算法,聚类将数据分开为不同的集合,分类对新数据进行类别预测,下面将就两类算法进行介绍. 1. 聚类和分类(1)什么是聚类 聚类( Clustering)指将数据对象分组 ...

  2. Hive自定义UDAF详解

    遇到一个Hive需求:有A.B.C三列,按A列进行聚合,求出C列聚合后的最小值和最大值各自对应的B列值.这个需求用hql和内建函数也可完成,但是比较繁琐,会解析成几个MR进行执行,如果自定义UDAF便 ...

  3. CentOS 搭建LNMP服务器和LAMP服务器

    CentOS 搭建LNMP服务器 方法一:yum安装 1.更新YUM源 wget http://www.atomicorp.com/installers/atomic   #下载atomic自动更新Y ...

  4. 在Tomcat上运行ADF Essentials应用

    Tomcat 7.0.32,Oracle ADF Essentials 12.1.2 Oracle ADF Essentials是Oracle ADF框架的免费版本.Oracle ADF essent ...

  5. [Windows驱动开发](一)序言

    笔者学习驱动编程是从两本书入门的.它们分别是<寒江独钓——内核安全编程>和<Windows驱动开发技术详解>.两本书分别从不同的角度介绍了驱动程序的制作方法. 在我理解,驱动程 ...

  6. java.util.Arrays的使用

    在Java.util包中有一个工具类Arrays类,封装了一些操作数组的方法.简单使用如下: package com.arrays.test; import java.util.Arrays; pub ...

  7. HDU 2136 Largest prime factor 參考代码

    #include <iostream> #include <vector> #include <cmath> using namespace std; const ...

  8. Js Pattern - Namespace Pattern

    bad code // BEFORE: 5 globals // Warning: antipattern // constructors function Parent() {} function ...

  9. Codeforces Beta Round #51 B. Smallest number dfs

    B. Smallest number Time Limit: 20 Sec Memory Limit: 256 MB 题目连接 http://codeforces.com/contest/55/pro ...

  10. 【Bootstrap3.0建站笔记三】AspNetPager分页,每一列都可排序

    1.AspNetPager分页,实现每一列都可排序:           (1).须要将默认排序字段放在HTML页面中.           (2).排序字段放置为td节点的属性. 如图: 实现的效果 ...