Scala(四) —— 集合
一、List
var x = List(1,2,3,4)
//x:List[Int] = List(1, 2, 3, 4)
var y = List("x","y","z")
//y: List[String] = List(x, y, z)
0 :: x
//res6: List[Int] = List(0, 1, 2, 3, 4)
x ::: y
//List[Any] = List(1, 2, 3, 4, x, y, z)
scala> "x"::"y"::"z"::Nil
res9: List[String] = List(x, y, z)
x.head //获取第一个元素
x.tail //获取除第一个元素的其他元素
x.isEmpty //判断该列表是否为空
字符串转List
var a = "HelloWorld,2018"
//a: String = HelloWorld,2018
a.toList
//res0: List[Char] = List(H, e, l, l, o, W, o, r, l, d, ,, 2, 0, 1, 8)
filter函数
a.toList.filter(x => Character.isDigit(x))
res1: List[Char] = List(2, 0, 1, 8)
//另一种简写方式
a.toList.filter(_.Character.isDigit(x))
takeWhile函数
a.toList.takeWhile(x => x!='d')
res2: List[Char] = List(H, e, l, l, o, W, o, r, l)
map函数
var a = List(1,2,3,4)
a.map(x => x % 2 == 0)
a.map(_%2 == 0)
var b = List(6,7,8)
var p = List(a,b)
a.map(_.filter(_%2 == 0))
//res14: List[List[Int]] = List(List(2, 4), List(8))
flatMap
a.flatMap(_.filter(_%2 == 0))
//res15: List[Int] = List(2, 4, 8)
reduce函数
a.reduce((x,y) => x+y)
//等价于
a.reduce(_+_)
foldLeft函数
a.fold(0)((x,y) => x+y)
//等价于
a.fold(0)(_+_)
二、Tuple元组
元组相当于数据库中的记录,可以放各种不同类型的值
val a = (1,2,3,4)
a._1 //访问元组中第一个元素
a._2 //访问元组中第二个元素
val b = (1,"fzj","math",95)
例子1:返回一条记录,计算一个列表的元素个数、元素之和,元素的平方和
val a = (1,2,3,4)
def sum(list:List[Int]):(Int,Int,Int)={
list.foldLeft(0,0,0)((x,y) => (x._1 + 1,x._2 + y,x._3 + y*y))
}
三、Set
var x = Set(1,2,3,4)
四、Map
(1) 创建Map
var x = Map("one" -> "1","two" -> "2")
var x:Map[String,String] = Map()
(2) 添加key-value
x += ("three" -> "three")
(3) 合并
使用 ++运算符 或 Map.++()方法来连接两个Map
var colors = color1 ++ color2
var colors = color1.++(color2)
(4) 遍历
val sites = Map("one"->"one","two"->"two","three"->"three")
sites.keys.foreach{
i =>
println("key="+i+",value="+sites(i))
}
Scala(四) —— 集合的更多相关文章
- Scala:集合类型Collection和迭代器
http://blog.csdn.net/pipisorry/article/details/52902549 Scala Collection Scala 集合分为可变的和不可变的集合. 可变集合可 ...
- Scala数组| 集合
arrays :+ 5尾部 头部5 +: arrays TODO 声明不可变数组,不能删; 默认情况下,scala中集合的声明全都是不可变的 val arrays: Array[Int] = Ar ...
- scala 可变集合与内存清理的关系
留坑待填 使用scala.collection.mutable._期间,发现了当程序运行内存开销较多时,使用系统工具进行内存清理,然后程序报出了变量找不到.内存无法访问.数组访问越界,堆栈溢出等多种错 ...
- Scala学习——集合的使用和“_”的一些使用(中)
1.空格加_可以表示函数的原型 命令行代码: scala> def fun1(name:String){println(name)} fun1: (name: String)Unit scala ...
- Scala(四)【集合基础入门】
目录 一.Array 二. List 三.Set 四.Tuple 五.Map 一.Array package com.bigdata.scala.day01 /** * @description: 不 ...
- Scala学习——集合
Scala集合 一.数组 package top.ruandb.scala.Course04 object ArrayApp { def main(args: Array[String]): Unit ...
- scala中集合的交集、并集、差集
scala中有一些api设计的很人性化,集合的这几个操作是个代表: 交集: scala> Set(1,2,3) & Set(2,4) // &方法等同于interset方法 sc ...
- 用Scala实现集合中相邻元素间的差值
欢迎转载,转载请注明出处,徽沪一郎. 概要 代码这东西,不写肯定不行,新学Scala不久,将实际遇到的一些问题记录下来,日后也好查找. 今天讲的是如何计算同一集合中元素两两之间的差值,即求开始集合(a ...
- 【Scala篇】--Scala中集合数组,list,set,map,元祖
一.前述 Scala在常用的集合的类别有数组,List,Set,Map,元祖. 二.具体实现 数组 1.创建数组 new Array[Int](10) 赋值:arr(0) = xxx Array[ ...
随机推荐
- vue 源码学习三 vue中如何生成虚拟DOM
vm._render 生成虚拟dom 我们知道在挂载过程中, $mount 会调用 vm._update和vm._render 方法,vm._updata是负责把VNode渲染成真正的DOM,vm._ ...
- Gradle 学习一
参考教程:https://guides.gradle.org/consuming-jvm-libraries/ 安装Gradle 下载地址:https://guides.gradle.org 配置环境 ...
- day03笔记
1.list操作stus = ['xiaohei','xiaobai','xiaohuang','cxdser'] #数组.list.array#增加stus.append('原宝')#在list末尾 ...
- win10 vscode使用 智能提示
1.没有第三方库的智能提示 参考:https://code.visualstudio.com/docs/python/editing 1.点开Settings 2.搜索加添加 3.添加后的内容 然后就 ...
- Spring中Model、ModelMap及ModelAndView之间的区别
Spring中Model.ModelMap及ModelAndView之间的区别 1. Model(org.springframework.ui.Model)Model是一个接口,包含addAttr ...
- 使用Apache服务部署静态网站
1970年,作为互联网前身的ARPANET(阿帕网)已初具雏形,并开始向非军用部门开放,许多大学和商业部门开始接入.虽然彼时阿帕网的规模(只有4台主机联网运行)还不如现在的局域网成熟,但是它依然为网络 ...
- MongoDB 错误汇总
错误1. ERROR: child process failed, exited with error number 100 可能原因: 1.没有正确关闭服务 2.服务已经启动 3.conf文件的参数 ...
- 基于docker搭建开源扫描器——伏羲
基于docker搭建开源扫描器——伏羲 1.简介 项目地址 伏羲是一款开源的安全检测工具,适用于中小型企业对企业内部进行安全检测和资产统计. 功能一览: 基于插件的漏洞扫描功能(类似于巡风) 漏洞管理 ...
- [Swift]LeetCode65. 有效数字 | Valid Number
Validate if a given string is numeric. Some examples:"0" => true" 0.1 " => ...
- [Swift]LeetCode575. 分糖果 | Distribute Candies
Given an integer array with even length, where different numbers in this array represent different k ...