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

 

posted on 2019-07-03 20:41  ligongda2006  阅读(101)  评论(0编辑  收藏  举报