zoukankan      html  css  js  c++  java
  • Scala中的数组和集合操作

    package test
    /* 1.在scala集合中,Iterable是共同的Trait,Iterable要求继承者实现一些共同的方法,例如元素的遍历
     * 2。Array是scala基础的数据结构,不从属于scala集合体系
     * 3.scala集合分为可变和不可变集合。,不可变集合在scala.collection.immutable里,可变在scala.collection.mutable
     * 
     * 4.List集合是不可变的,head指第一个元素,tail指剩下的元素组成的集合,而LinkedList可变
     * 5.使用双冒号::将list集合和其他元素组成新的集合
     * 6.当集合中没有元素时,返回Nil
     * 7.Set是不可重复的集合
     * 
     */
    object Sacla_Iterable {
        def main(args: Array[String]): Unit = {
                val range = 1 to 10
                
                val list = List(1,2,3,4)
                println(list)
                println(0::list)//使用双冒号::将list集合和其他元素组成新的集合
                
                var linkedList=scala.collection.mutable.LinkedList(1,12,2,3,5)
                while(linkedList!=Nil){//当集合中没有元素时,返回Nil,head指第一个元素,tail指剩下的元素组成的集合
                  println(linkedList.head)
                  linkedList=linkedList.tail
                }
                println(linkedList)
                val linkedList2=linkedList.+:(9)
                println("linkedList2: "+linkedList2)
                
                val set=Set(1,4,6,8)
                println("Set: "+set)
                var hashSet=scala.collection.mutable.HashSet(3,6,8,90)
                println("hashSet: "+hashSet)
                hashSet+=12
                hashSet+=0
                println("hashSet: "+hashSet)
                
                var linkedHashSet= scala.collection.mutable.LinkedHashSet(1,4,2,7,0)
          println("linkedHashSet: "+linkedHashSet)
            linkedHashSet+=3
            linkedHashSet+=6
            println("linkedHashSet: "+linkedHashSet) 
                
                var sortSet=scala.collection.mutable.SortedSet(1,4,2,7,0)
            println("sortSet: "+sortSet)
            sortSet+=3
            sortSet+=6
            println("sortSet: "+sortSet) 
                
                var li=List("hello my princess","this is mine !")
                println("li: "+li)
                var li_flatMap=li.flatMap( x => x.split(" ") )//flatMap根据函数操作生成新的集合
            println("li_flatMap: "+li_flatMap)
            var li_flatMap_map=li_flatMap.map(x => (x ,"_kang"))//map对每个集合元素进行操作
            println("li_flatMap_map: "+li_flatMap_map)
            var li_flatMap_map_map=li_flatMap_map.map(x =>x._2).reduce(_+_)
            println("li_flatMap_map_map: "+li_flatMap_map_map)
            
            //占位符
            List(1, 4, 2, 7, 0, 3, 6).foreach( x => println(x))
            List(1, 4, 2, 7, 0, 3, 6).foreach( _ => println _ )
            List(1, 4, 2, 7, 0, 3, 6).foreach( println(_))
            List(1, 4, 2, 7, 0, 3, 6).foreach( println _ )
            
            
        }
    }
  • 相关阅读:
    P2567 [SCOI2010]幸运数字 DFS+容斥定理
    Codeforces Round #462 (Div. 2) C DP
    Codeforces Round #428 (Div. 2) C. dfs
    POJ 2079 最大三角形面积(凸包)
    POJ 3608 凸包间最短距离(旋转卡壳)
    2018年全国多校算法寒假训练
    Educational Codeforces Round 37 E. Connected Components?(图论)
    UVa 1440:Inspection(带下界的最小流)***
    BZOJ 1483:[HNOI2009]梦幻布丁(链表启发式合并)
    PAT L3-016:二叉搜索树的结构(暴力)
  • 原文地址:https://www.cnblogs.com/itboys/p/9280499.html
Copyright © 2011-2022 走看看