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

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

数组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中的数组的更多相关文章
- 2. scala中的数组
一. 数组声明 定长数组 scala> new Array[String](5) res1: Array[String] = Array(null, null, null, null, null ...
- 【Scala篇】--Scala中集合数组,list,set,map,元祖
一.前述 Scala在常用的集合的类别有数组,List,Set,Map,元祖. 二.具体实现 数组 1.创建数组 new Array[Int](10) 赋值:arr(0) = xxx Array[ ...
- Scala中的数组和集合操作
package test /* 1.在scala集合中,Iterable是共同的Trait,Iterable要求继承者实现一些共同的方法,例如元素的遍历 * 2.Array是scala基础的数据结构, ...
- scala中的数组的转换操作
1.共有两种操作 转换成一种新的数组 2.yield转换 3.函数式编程转换
- Programming In Scala笔记-第十七章、Scala中的集合类型
本章主要介绍Scala中的集合类型,主要包括:Array, ListBuffer, Arraybuffer, Set, Map和Tuple. 一.序列 序列类型的对象中包含多个按顺序排列好的元素,可以 ...
- Scala学习(三)----数组相关操作
数组相关操作 摘要: 本篇主要学习如何在Scala中操作数组.Java和C++程序员通常会选用数组或近似的结构(比如数组列表或向量)来收集一组元素.在Scala中,我们的选择更多,不过现在我们先假定不 ...
- Scala中Zip相关的函数
在Scala中存在好几个Zip相关的函数,比如zip,zipAll,zipped 以及zipWithIndex等等.我们在代码中也经常看到这样的函数,这篇文章主要介绍一下这些函数的区别以及使用. 1. ...
- [原创]Scala学习:数组的基本操作,数组进阶操作,多维数组
1.Scala中提供了一种数据结构-数组,其中存储相同类型的元素的固定大小的连续集合.数组用于存储数据的集合,但它往往是更加有用认为数组作为相同类型的变量的集合 2 声明数组变量: 要使用的程序的数组 ...
- Scala中的If判断&While&For循环
If 判断: object TestScalaIf { def main(args: Array[String]): Unit = { // val resutlt = judge1(-100) // ...
随机推荐
- 启动程序的同时传参给接收程序(XE8+WIN764)
相关资料: http://blog.csdn.net/yanjiaye520/article/details/7590252 注意事项: 1.ParamStr(0)是实例自己. 2.传的参数是以空格分 ...
- 回车跳到下一个EDIT
1.按下方法procedure TForm2.Edit1KeyDown(Sender: TObject; var Key: Word; Shift: TShiftState);begin if Key ...
- Test Spring el with ExpressionParser
Spring expression language (SpEL) supports many functionality, and you can test those expression fea ...
- 什么是APNs证书?
转载自 http://dev.xiaomi.com/doc/p=2977/index.html 什么是APNs和APNs证书? APNs(全称为Apple Push Notification Serv ...
- UVA 11354 Bond(MST + LCA)
n<=50000, m<=100000的无向图,对于Q<=50000个询问,每次求q->p的瓶颈路. 其实求瓶颈路数组maxcost[u][v]有用邻接矩阵prim的方法.但是 ...
- [置顶] 栈/入栈/出栈顺序(c语言)-linux
说明: 1.栈底为高地址,栈顶为低地址. 2.入栈顺序:从右到左. 解释1:栈在内存中的结构 [注:0x00 到 0x04之间间隔4个地址] 入栈:指针先指向0x10,从高地址向低地址方向填数值,最终 ...
- C++多态实现(虚函数,成员函数覆盖、隐藏)
// 1.cpp : 定义控制台应用程序的入口点. // #include "stdafx.h" #include <iostream> using namespace ...
- [前端JS学习笔记]JavaScript prototype 对象
一.概念介绍 prototype 对象 : 原型对象.在JavaScript中, 每一个对象都继承了另一个对象,后者称为"原型对象". 只有 null 除外,它没有自己的原型对象. ...
- 【不积跬步,无以致千里】AMQP协议介绍
国内私募机构九鼎控股打造APP,来就送 20元现金领取地址:http://jdb.jiudingcapital.com/phone.html内部邀请码:C8E245J (不写邀请码,没有现金送)国内私 ...
- Codeforces Round #331 (Div. 2) E. Wilbur and Strings dfs乱搞
E. Wilbur and Strings Time Limit: 20 Sec Memory Limit: 256 MB 题目连接 http://codeforces.com/contest/596 ...