Spark记录-Scala数组/List/Map/Set

import Array._

import scala.collection.mutable.Set

object DataStructure {

 def main(args:Array[String]):Unit={

   //数组

   var z:Array[String] = new Array[String](3);

   var z1 = new Array[String](3);

   z(0)="hello";

   z1(0)="world";

   var z2 = Array("Runoob""Baidu""Google");

   for(zz<-z2){

     println(zz)

   }

   var myList = Array(1.92.93.43.5)

   // 输出所有数组元素

   for ( x <- myList ) {

     println( x )

   }

   // 计算数组所有元素的总和

   var total = 0.0;

   for ( i <- 0 to (myList.length - 1)) {

     total += myList(i);

   }

   println("总和为 " + total);

 

   // 查找数组中的最大元素

   var max = myList(0);

   for ( i <- 1 to (myList.length - 1) ) {

     if (myList(i) > max) max = myList(i);

   }

   println("最大值为 " + max);

 

   var myMatrix = ofDim[Int](3,3)

   // 创建矩阵

   for (i <- 0 to 2) {

     for ( j <- 0 to 2) {

       myMatrix(i)(j) = j;

     }

   }

   // 打印二维阵列

   for (i <- 0 to 2) {

     for ( j <- 0 to 2) {

       print(" " + myMatrix(i)(j));

     }

     println();

   }

   //合并数组

   var myList1 = Array(1.92.93.43.5)

   var myList2 = Array(8.97.90.41.5)

   var myList3 =  concat( myList1, myList2)

   // 输出所有数组元素

   for ( x <- myList3 ) {

     println( x )

   }

   //创建区间数组

   var myList4 = range(10202)

   var myList5 = range(10,20)

 

   // 输出所有数组元素

   for ( x <- myList4 ) {

     print( " " + x )

   }

   println()

   for ( x <- myList5 ) {

     print( " " + x )

   }

   //List列表

   // 字符串列表

   val site: List[String] = List("Runoob""Google""Baidu")

 

   // 整型列表

   val nums: List[Int] = List(1234)

 

   // 空列表

   val empty: List[Nothing] = List()

 

   // 二维列表

   val dim: List[List[Int]] =

     List(

       List(100),

       List(010),

       List(001)

     )

   // 字符串列表

   val site1 = "Runoob" :: ("Google" :: ("Baidu" :: Nil))

 

   // 整型列表

   val nums1 = 1 :: (2 :: (3 :: (4 :: Nil)))

 

   // 空列表

   val empty1 = Nil

 

   // 二维列表

   val dim1 = (1 :: (0 :: (0 :: Nil))) ::

     (0 :: (1 :: (0 :: Nil))) ::

     (0 :: (0 :: (1 :: Nil))) :: Nil

 

   /***

     * head 返回列表第一个元素

        tail 返回一个列表,包含除了第一元素之外的其他元素

        isEmpty 在列表为空时返回true

     */

   val site2 = "Runoob" :: ("Google" :: ("Baidu" :: Nil))

   val nums2 = Nil

 

   println( "第一网站是 : " + site2.head )

   println( "最后一个网站是 : " + site2.tail )

   println( "查看列表 site 是否为空 : " + site2.isEmpty )

   println( "查看 nums 是否为空 : " + nums2.isEmpty )

   val site3 = "Runoob" :: ("Google" :: ("Baidu" :: Nil))

   val site4 = "Facebook" :: ("Taobao" :: Nil)

 

   // 使用 ::: 运算符

   var fruit = site3 ::: site4

   println( "site3 ::: site4 : " + fruit )

 

   // 使用 Set.:::() 方法

   fruit = site3.:::(site4)

   println( "site3.:::(site4) : " + fruit )

 

   // 使用 concat 方法

   fruit = List.concat(site3, site4)

   println( "List.concat(site3, site4) : " + fruit  )

 

   val site5 = List.fill(3)("Runoob"// 重复 Runoob 3次

   println( "site5 : " + site5  )

 

   val num2 = List.fill(10)(2)         // 重复元素 2, 10 次

   println( "num2 : " + num2  )

   // 通过给定的函数创建 5 个元素

   val squares = List.tabulate(6)(n => n * n)

   println( "一维 : " + squares  )

 

   // 创建二维列表

   val mul = List.tabulate( 4,5 )( _ _ )

   println( "多维 : " + mul  )

   //反转

   val site6 = "Runoob" :: ("Google" :: ("Baidu" :: Nil))

   println( "site6 反转前 : " + site6 )

   println( "site6 反转后 : " + site6.reverse )

   //Set集合

   val site7 = Set("Runoob""Google""Baidu")

   val nums6: Set[Int] = Set()

   println( "第一网站是 : " + site7.head )

   println( "最后一个网站是 : " + site7.tail )

   println( "查看列表 site 是否为空 : " + site7.isEmpty )

   println( "查看 nums 是否为空 : " + nums6.isEmpty )

   // ++ 作为运算符使用--连接

   var site8 = site7 ++ nums6

   println( "site1 ++ site2 : " + site8 )

   val site10 = Set("Faceboook""Taobao")

   //  ++ 作为方法使用

   site8 = site7.++(site10)

   println( "site1.++(site2) : " + site8 )

   val num = Set(5,6,9,20,30,45)

 

   // 查找集合中最大与最小元素

   println( "Set(5,6,9,20,30,45) 集合中的最小元素是 : " + num.min )

   println( "Set(5,6,9,20,30,45) 集合中的最大元素是 : " + num.max )

   val num1 = Set(5,6,9,20,30,45)

   val num3 = Set(50,60,9,20,35,55)

 

   // 交集

   println( "num1.&(num2) : " + num1.&(num3) )

   println( "num1.intersect(num2) : " + num1.intersect(num3) )

   //Map映射

   var A:Map[Char,Int] = Map()

   A += ('I' -> 1)

   A += ('J' -> 5)

   A += ('K' -> 10)

   A += ('L' -> 100)

   println( "colors 中的键为 : " + A.keys )

   println( "colors 中的值为 : " + A.values )

   println( "检测 colors 是否为空 : " + A.isEmpty )

   //连接

   val colors1 = Map("red" -> "#FF0000",

     "azure" -> "#F0FFFF",

     "peru" -> "#CD853F")

   val colors2 = Map("blue" -> "#0033FF",

     "yellow" -> "#FFFF00",

     "red" -> "#FF0000")

 

   //  ++ 作为运算符

   var colors = colors1 ++ colors2

   println( "colors1 ++ colors2 : " + colors )

 

   //  ++ 作为方法

   colors = colors1.++(colors2)

   println( "colors1.++(colors2)) : " + colors )

   //foreach循环

   val sites = Map("runoob" -> "http://www.runoob.com",

     "baidu" -> "http://www.baidu.com",

     "taobao" -> "http://www.taobao.com")

 

   sites.keys.foreach{ i =>

     print( "Key = " + i )

     println(" Value = " + sites(i) )}

   if( sites.contains( "runoob" )){

     println("runoob 键存在,对应的值为 :"  + sites("runoob"))

   }else{

     println("runoob 键不存在")

   }

   if( sites.contains( "baidu" )){

     println("baidu 键存在,对应的值为 :"  + sites("baidu"))

   }else{

     println("baidu 键不存在")

   }

   if( sites.contains( "google" )){

     println("google 键存在,对应的值为 :"  + sites("google"))

   }else{

     println("google 键不存在")

   }

   //Iterator(迭代器)

   /**

     * Scala Iterator(迭代器)不是一个集合,它是一种用于访问集合的方法。

     迭代器 it 的两个基本操作是 next 和 hasNext。

     调用 it.next() 会返回迭代器的下一个元素,并且更新迭代器的状态。

     调用 it.hasNext() 用于检测集合中是否还有元素。

      让迭代器 it 逐个返回所有元素最简单的方法是使用 while 循环:

     */

   val it = Iterator("Baidu""Google""Runoob""Taobao")

   while (it.hasNext){

     println(it.next())

   }

   val ita = Iterator(20,40,2,50,6990)

   val itb = Iterator(20,40,2,50,6990)

   println("最大元素是:" + ita.max )

   println("最小元素是:" + itb.min )

   println("ita.size 的值: " + ita.size )

   println("itb.length 的值: " + itb.length )

 }

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值