Scala基础知识笔记4-集合

 

 

    /**
      * 集合类常用高级函数
      * 高阶函数两个特点:
      * 函数接收函数作为参数
      * 函数返回函数作为返回值
      * map
      * flatmap
      * reduce
      * reduceleft
      * foreach
      * reducebykey
      * groupbykey
      */
    var list1 = List(1,2,3,4)
    var list2 = 0::list1 // 合并到集合中
    //list1.head  // 第一个元素 1
    //list1.tail //  第一个元素之后的其余元素 2,3,4
    //print(list2)

    var list3 = scala.collection.mutable.LinkedList(1,2,3,4,5,6)
    //println(list3.elem) // 1
    //println(list3.next)  // LinkedList(2, 3, 4, 5, 6)

    val list = scala.collection.mutable.LinkedList(1, 2, 3, 4, 5)
    var list4 = list.map(_*2)
    //var list5 = list.map("the num is: " + _)
    //println(list5)
    //println(list4)
    /*for(i<- 0 until list.length) {
      print(list(i))
    }*/
    //var list5 = List("hello world","you name is").map(_.toUpperCase())
    // flatmap是map的一个扩展,在flatmap函数体里,会传入一个函数,该函数对每个输入都返回一个集合,然后flatmap会把所有的集合都拍扁形成一个集合,如下例子:
    var list5 = List("hello world","you name is").flatMap(_.split(" ")) // List(hello, world, you, name, is)
    println(list5)
    // set
    // 0 定义
    var s = Set(1,2,3) // 定义初始化的set 非可变 乱序  不可重复
    // 1 添加元素
    //var s1 = s+1 // 使用此方法添加元素
    //println(s1)

    var s1 = scala.collection.mutable.HashSet[Int]() // 定义空set  使用链表方式维护插入顺序
    s1 += 4 // 使用 += 添加元素
    s1 += 5
    //println(s1)  // Set(5, 4)

    var s2 = scala.collection.mutable.SortedSet[String]()
    s2 += "hello"
    s2 += "tello"
    //println(s2) // TreeSet(hello, tello)


    var list7 = List("zm","liangliang").zip(List(32,31)) // 合并两个有序集合成为一个键值对集合  使用拉链操作 zip
    println(list7) // List((zm,32), (liangliang,31))

    //val lines01 = scala.io.Source.fromFile("C://Users//Administrator//Desktop//test01.txt").mkString
   // val lines02 = scala.io.Source.fromFile("C://Users//Administrator//Desktop//test02.txt").mkString
    //var lines = List(lines01,lines02)
    var lines = List("hello world you ","hello world me ") // 统计文件中单词的总个数 不是单词计数 是所有单词总个数
    // 把每个单词映射成 单词,1 这种元组形式, 然后针对每个tuple 映射出右侧的那个1 出,然后针对这些个1进行累加
    // (hello,1) (world,1) (you,1) (hello,1) (world,1) (me,1)
    var result = lines.flatMap(_.split(" ")).map((_, 1)).map(_._2).reduceLeft(_ + _) // (1+1)+1 + 1 + 1 + 1
    //lines.flatMap(_.split(" ")).map((_,1)).map(_._2).reduceLeft((_+_))
   println(result) // 结果是 6 个单词
    var firstTuple = ("str", 1 , 0.5)  // 定义元组
    //println(firstTuple._1)  // 获取元组指定位置的值  结果为 str

 

原文地址:https://www.cnblogs.com/chengjianxiaoxue/p/11128934.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


共收录Twitter的14款开源软件,第1页Twitter的Emoji表情 TwemojiTwemoji是Twitter开源的其完整的Emoji表情图片。开发者可以去GitHub下载完整的表情库,并把这些表情加入到自己的应用或网页中。使用示例:var i = 0;twemoji.parse(  ’emoji, m\u276
Java和Scala中关于==的区别Java:==比较两个变量本身的值,即两个对象在内存中的首地址;equals比较字符串中所包含的内容是否相同。publicstaticvoidmain(String[]args){​ Strings1="abc"; Strings2=newString("abc");​ System.out.println(s1==s2)
本篇内容主要讲解“Scala怎么使用”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Scala怎么使用”吧!语法scala...
这篇文章主要介绍“Scala是一种什么语言”,在日常操作中,相信很多人在Scala是一种什么语言问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,
这篇文章主要介绍“Scala Trait怎么使用”,在日常操作中,相信很多人在Scala Trait怎么使用问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,
这篇文章主要介绍“Scala类型检查与模式匹配怎么使用”,在日常操作中,相信很多人在Scala类型检查与模式匹配怎么使用问题上存在疑惑,小编查阅了各式资料,整理...
这篇文章主要介绍“scala中常用但不常见的符号有哪些”,在日常操作中,相信很多人在scala中常用但不常见的符号有哪些问题上存在疑惑,小编查阅了各式资料,整理...
本篇内容主要讲解“Scala基础知识有哪些”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Scala基础知识有哪些”...
本篇内容介绍了“scala基础知识点有哪些”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧...
本篇内容介绍了“Scala下划线怎么使用”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧...
本篇内容主要讲解“Scala提取器怎么使用”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Scala提取器怎么使用”...
这篇文章主要讲解了“Scala基础语法有哪些”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Scala基础语法有...
本篇内容主要讲解“Scala方法与函数怎么使用”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Scala方法与函数怎...
这篇文章主要讲解了“scala条件控制与循环怎么实现”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“scala条...
这篇文章主要介绍“scala函数怎么定义和调用”,在日常操作中,相信很多人在scala函数怎么定义和调用问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操
这篇文章主要介绍“scala如何声明变量”,在日常操作中,相信很多人在scala如何声明变量问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对...
这篇文章主要讲解了“scala的Map和Tuple怎么使用”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“scala的Ma...
这篇文章主要介绍“scala的隐式参数有什么作用”,在日常操作中,相信很多人在scala的隐式参数有什么作用问题上存在疑惑,小编查阅了各式资料,整理出简单好用的...
本篇内容主要讲解“Scala怎么进行文件写操作”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Scala怎么进行文件...
这篇文章主要讲解了“Scala怎么声明数组”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Scala怎么声明数组...