Scala数组相关操作&练习

1. 1. 编写一段代码,将a设置为一个包含n个随机整数的数组,要求随机数介于0(包含)和n(不包含)之间

def main (args: Array[String]) {
  createArr(10).foreach(println)
}
def createArr(n:Int):Array[Int]={
  val arr=new Array[Int](n)
  val rand=new Random()
  for(ele <- arr)
    yield rand.nextInt(n)
}

2. 编写一个循环,将整数数组中相邻的元素置换。例如,Array(1,2,3,4,5) 经过置换后变为Array(2,1,4,3,5)

def main (args: Array[String]) {
  val a=Array(1,2,3,4,5)
  Swap(a)
  a.foreach(print)
}
def Swap(arr:Array[Int]):Unit={
  for(i <- 0 until (arr.length-1,2)){
    val tmp=arr(i)
    arr(i)=arr(i+1)
    arr(i+1)=tmp
  }
}

3. 重复前一个练习,不过这一次生成一个新的值交换过的数组。用for/yield

def main (args: Array[String]) {
  val a=Array(1,2,3,4,5)
  val b=SwapYield(a)
  b.foreach(print)
}
def SwapYield(arr:Array[Int])={
  for(i <- 0 until arr.length) yield {
    if (i<(arr.length-1) && i%2==0){
      val tmp=arr(i)
      arr(i)=arr(i+1)
      arr(i+1)=tmp
    }
    arr(i)
  }
}

4. 给定一个整数数组,产出一个新的数组,包含元数组中的所有正值,以原有顺序排列,之后的元素是所有零或负值,以原有顺序排列

def main (args: Array[String])= {
  val a=Array(1,-2,0,-3,1,2)
  val b=sigArr(a)
  b.foreach(println)
}
def sigArr(arr:Array[Int])={
  val buff=new ArrayBuffer[Int]()
  buff++=(for(ele <- arr if ele>0) yield ele)
  buff++=(for(ele <- arr if ele==0) yield ele)
  buff++=(for(ele <- arr if ele<0) yield ele )
  buff.toArray
}

5. 如何计算Array[Double]的平均值

def main (args: Array[String])= {
  val a=Array[Double](1,4,2,10,3,-1,-3)
  val b=Avgarr(a)
  println(b)
}
def Avgarr(arr:Array[Double])={
  arr.sum/arr.length
}

6. 如何重新组织A r r a y [ I n t ] 的元素将它们以反序排列,对于ArrayBuffer[Int]你又会怎么做呢

def main (args: Array[String])= {
  val a=Array(5,4,3,2,1)
  resverseArr(a)
  a.foreach(println)

  //ArrayBuffer反转
  val b=ArrayBuffer(1,2,3,4,5)
  val c=ArrayBuffer[Int]()
  c++=b.reverse
  c.foreach(println)
}

def resverseArr(arr:Array[Int]) {
  val len=arr.length
  for(i <- 0 until len/2){
    val tmp=arr(i)
    arr(i)=arr(len-1-i)
    arr(len-1-i)=tmp
  }
}

7. 编写一段代码,产出数组中的所有值,去掉重复项。(提示:查看Scaladoc)

def main (args: Array[String])= {
  val a=ArrayBuffer(1,2,2,23,3,4,5,6,3)
  val b=ArrayBuffer[Int]()
  b++=a.distinct
  b.foreach(println)
}

8. 收集负值元素的下标,反序,去掉最后一个下标,然后对每一个下标调用a.remove(i)。

def main (args: Array[String])= {
  val a=Array(1,-2,3,4,5,-1,-3,-4)
  val b= delRevFirst(a)
  b.foreach(println)
}

def delRevFirst(arr:Array[Int])={
  val indexs=for(i <- 0 until arr.length if arr(i)<0) yield i
  val dropindexs=indexs.reverse.dropRight(1)
  val tmp=arr.toBuffer
  for(index <- dropindexs)
    tmp.remove(index)
  tmp
}

9. 创建一个由Java.util.TimeZone.getAvailableIDs返回的时区集合,判断条件是它们在美洲。去掉"America/"前缀并排序

def main (args: Array[String])= {
  val a=TimeZone()
  a.foreach(println)
}
def TimeZone()={
  val arr=java.util.TimeZone.getAvailableIDs()
  val tmp=for(ele <-arr if ele.startsWith("America/")) yield {
    ele.drop("America/".length)
  }
  scala.util.Sorting.quickSort(tmp)
  tmp
}

10. 引入java.awt.datatransfer._并构建一个类型为SystemFlavorMap类型的对象

def main (args: Array[String])= {
  val flavors = SystemFlavorMap.getDefaultFlavorMap().asInstanceOf[SystemFlavorMap]
  println(flavors.getNativesForFlavor(DataFlavor.imageFlavor).toArray.toBuffer.mkString(" | "))
}

如果,您认为阅读这篇博客让您有些收获,不妨点击一下右下角的【推荐】。
如果,您希望更容易地发现我的新博客,不妨点击一下左下角的【关注我】。
如果,您对我的博客所讲述的内容有兴趣,请继续关注我的后续博客,我是【Sunddenly】。

本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留追究法律责任的权利。

Scala学习(三)练习的更多相关文章

  1. Scala学习(三)----数组相关操作

    数组相关操作 摘要: 本篇主要学习如何在Scala中操作数组.Java和C++程序员通常会选用数组或近似的结构(比如数组列表或向量)来收集一组元素.在Scala中,我们的选择更多,不过现在我们先假定不 ...

  2. Scala学习三——数组相关操作

    一.若长度固定则使用Array,若长度可能有变化则使用ArrayBuffer 固定长度数组: 如val nums=new Array[Int](10) //10个整型数组,所有元素初始化为0; val ...

  3. 机器学习(三)--- scala学习笔记

    Scala是一门多范式的编程语言,一种类似Java的编程语言,设计初衷是实现可伸缩的语言.并集成面向对象编程和函数式编程的各种特性. Spark是UC Berkeley AMP lab所开源的类Had ...

  4. 【Todo】【读书笔记】大数据Spark企业级实战版 & Scala学习

    下了这本<大数据Spark企业级实战版>, 另外还有一本<Spark大数据处理:技术.应用与性能优化(全)> 先看前一篇. 根据书里的前言里面,对于阅读顺序的建议.先看最后的S ...

  5. 【大数据】Scala学习笔记

    第 1 章 scala的概述1 1.1 学习sdala的原因 1 1.2 Scala语言诞生小故事 1 1.3 Scala 和 Java  以及 jvm 的关系分析图 2 1.4 Scala语言的特点 ...

  6. 基于.net的分布式系统限流组件 C# DataGridView绑定List对象时,利用BindingList来实现增删查改 .net中ThreadPool与Task的认识总结 C# 排序技术研究与对比 基于.net的通用内存缓存模型组件 Scala学习笔记:重要语法特性

    基于.net的分布式系统限流组件   在互联网应用中,流量洪峰是常有的事情.在应对流量洪峰时,通用的处理模式一般有排队.限流,这样可以非常直接有效的保护系统,防止系统被打爆.另外,通过限流技术手段,可 ...

  7. Scala学习资源

    Scala学习资源: Scala官方网站:http://www.scala-lang.org/ Scala github:https://github.com/scala/scala Twitter ...

  8. HTTP学习三:HTTPS

    HTTP学习三:HTTPS 1 HTTP安全问题 HTTP1.0/1.1在网络中是明文传输的,因此会被黑客进行攻击. 1.1 窃取数据 因为HTTP1.0/1.1是明文的,黑客很容易获得用户的重要数据 ...

  9. TweenMax动画库学习(三)

    目录               TweenMax动画库学习(一)            TweenMax动画库学习(二)            TweenMax动画库学习(三)           ...

随机推荐

  1. 《Inside C#》笔记(十一) 运算符重载

    运算符重载与之前的索引器类似,目的是为了让语言本身使用起来更方便直接,也是一种语法糖. 一 运算符重载(Operator Overloading) 运算符重载的存在,使得现有的各种运算符可以被重新定义 ...

  2. flask表单

    一.原生表单 模板页面 <form action="{{ url_for('check') }}" method="post"> <p> ...

  3. 10-openldap同步原理

    openldap同步原理 阅读视图 openldap同步原理 syncrepl.slurpd同步机制优缺点 OpenLDAP同步条件 OpenLDAP同步参数 1. openldap同步原理 Open ...

  4. sleep和Sleep区别

    windows Sleep 单位是毫秒 linux sleep 单位是秒

  5. python中json序列化的东东

    之所以写这个因为自己总是弄混了,容易弄错,记下来有事没事看看   序列化是指把变量从内存中变成可存储或传输的过程称之为序列化用(使用dump或者dumps),把变量内容从序列化的对象重新读到 内存里称 ...

  6. Business talking in English

    Talking one: A: Microsoft, this is Steve. B: Hi Steve, this is Richard from Third Hand Testing. I am ...

  7. JavaWeb后台购物车类的具体实现

    相信大家肯定都在电商网站买过东西,当我们看中一件喜欢又想买的东西时,这时候你又不想这么快结账,这时候你就可以放入购物车: 就像我们平时去超市买东西一样,会推着购物车去买东西: 那么我们接下来看看jav ...

  8. pip安装django的时候提示没有这个命令

    问题描述: 在安装pyenv安装完python的时候,用pip安装django提示没有这个命令 [root@zabbix ~]# pip install django== 2.0 pyenv: pip ...

  9. Hadoop2.7.6_05_mapreduce-Yarn

    1. MAPREDUCE原理 Mapreduce是一个分布式运算程序的编程框架,是用户开发“基于hadoop的数据分析应用”的核心框架: Mapreduce核心功能是将用户编写的业务逻辑代码和自带默认 ...

  10. kafka 配置文件参数详解

    kafka的配置分为 broker.producter.consumer三个不同的配置 一 BROKER 的全局配置 最为核心的三个配置 broker.id.log.dir.zookeeper.con ...