1.数组操作

  1.定长数组:val nums = new Array[Int](10)

        val s=Array("tom","lisi")

    *在jvm中,Scala的Array以java数组的方式实现。

  2.变长数组(数组缓冲):ArrayBuffer

      val b=ArrayBuffer[Int]()

    1.基本操作:

      1.在尾部添加元素  b+=1

      2.在尾部添加多个元素 b+=(2,3,4)

      3.在尾部添加集合 b++=Array(2,5,6)

      4.在指定位置插入元素 b.insert(2,4,5,6)    //在坐标为2的位置添加4,5,6

      5.移除指定位置的元素 b.remove(2)    //移除坐标为2的元素

      6.移除指定位置后的若干元素 b.remove(2,4)  //移除从坐标为2开始的4个元素

      7.移除末尾的若干元素  b.trimEnd(4)    //移除末尾的4个元素

    2.数组的遍历

      1.for(i <- 0 until 数组.length) println(数组(i))

       for(i <- 0 until (数组.length,步长)) println(数组(i))

       for(i <- 0 until (数组.length,步长) reverse) println(数组(i))

      2.for(元素 <- 数组) println(元素)

    3.数组转换

      1.for推导式:for(元素 <- 数组) yield 对元素的处理     //返回元素处理后的数组

      2.守卫(for中的if实现):for(元素  <- 数组 if 元素满足的条件) yield 对满足条件的元素的处理     //返回对满足条件的元素处理后的数组

        *可以通过 数组.filter(_%2==2).map(3*_)     //_代表元素,返回对满足条件的元素处理后的数组

    4.常用算法

      1.数组.sum     //求和

      2.数组.max  //求最大值或最长的值

      3.数组.sorted(_>_)  降序    数组.sorted(_<_)  升序   //返回经过排序后的数组或数组缓冲

      4.scala.util.Sorting.quickSort(数组)    //只能是数组不能是数组缓冲,对原数组直接排序

      5.数组.mkString(连接符)     //将数组中的元素通过指定的连接符连接成一个字符串

      6.数组.mkString(前缀,连接符,后缀)    //返回带有前后缀的通过连接符连接成的字符串

    5.多维数组

      val m=Array.ofDim[Int](3,4)   //创建一个3行4列的二维数组

      val t=new Array[Array[Int]](10)   //创建一个10行的数组

      数组(行)(列)

    6.ArrayBuffer和java中的list相关转换

      

      

02scala基础的更多相关文章

  1. java基础集合经典训练题

    第一题:要求产生10个随机的字符串,每一个字符串互相不重复,每一个字符串中组成的字符(a-zA-Z0-9)也不相同,每个字符串长度为10; 分析:*1.看到这个题目,或许你脑海中会想到很多方法,比如判 ...

  2. node-webkit 环境搭建与基础demo

    首先去github上面下载(地址),具体更具自己的系统,我的是windows,这里只给出windows的做法 下载windows x64版本 下载之后解压,得到以下东西 为了方便,我们直接在这个目录中 ...

  3. js学习笔记:webpack基础入门(一)

    之前听说过webpack,今天想正式的接触一下,先跟着webpack的官方用户指南走: 在这里有: 如何安装webpack 如何使用webpack 如何使用loader 如何使用webpack的开发者 ...

  4. Golang, 以17个简短代码片段,切底弄懂 channel 基础

    (原创出处为本博客:http://www.cnblogs.com/linguanh/) 前序: 因为打算自己搞个基于Golang的IM服务器,所以复习了下之前一直没怎么使用的协程.管道等高并发编程知识 ...

  5. [C#] C# 基础回顾 - 匿名方法

    C# 基础回顾 - 匿名方法 目录 简介 匿名方法的参数使用范围 委托示例 简介 在 C# 2.0 之前的版本中,我们创建委托的唯一形式 -- 命名方法. 而 C# 2.0 -- 引进了匿名方法,在 ...

  6. HTTPS 互联网世界的安全基础

    近一年公司在努力推进全站的 HTTPS 化,作为负责应用系统的我们,在配合这个趋势的过程中,顺便也就想去搞清楚 HTTP 后面的这个 S 到底是个什么含义?有什么作用?带来了哪些影响?毕竟以前也就只是 ...

  7. Swift与C#的基础语法比较

    背景: 这两天不小心看了一下Swift的基础语法,感觉既然看了,还是写一下笔记,留个痕迹~ 总体而言,感觉Swift是一种前后端多种语言混合的产物~~~ 做为一名.NET阵营人士,少少多多总喜欢通过对 ...

  8. .NetCore MVC中的路由(1)路由配置基础

    .NetCore MVC中的路由(1)路由配置基础 0x00 路由在MVC中起到的作用 前段时间一直忙于别的事情,终于搞定了继续学习.NetCore.这次学习的主题是MVC中的路由.路由是所有MVC框 ...

  9. .NET基础拾遗(5)多线程开发基础

    Index : (1)类型语法.内存管理和垃圾回收基础 (2)面向对象的实现和异常的处理基础 (3)字符串.集合与流 (4)委托.事件.反射与特性 (5)多线程开发基础 (6)ADO.NET与数据库开 ...

随机推荐

  1. paper 33 :[教程] 如何使用libsvm进行分类

    文章来源:http://www.matlabsky.com/thread-12379-1-1.html 这篇文章的讲解的真的是言简意赅,很简单的例子就把这个入门的门槛降低了不少,目前的情况是,我都晓得 ...

  2. Oracle的分页查询

    --1:无ORDER BY排序的写法.(效率最高)--(经过测试,此方法成本最低,只嵌套一层,速度最快!即使查询的数据量再大,也几乎不受影响,速度依然!) SELECT * FROM (SELECT ...

  3. PAT乙级 1005. 继续(3n+1)猜想 (25)

    1005. 继续(3n+1)猜想 (25) 时间限制 400 ms 内存限制 65536 kB 代码长度限制 8000 B 判题程序 Standard 作者 CHEN, Yue 卡拉兹(Callatz ...

  4. MapReduce:详解Shuffle过程

    Shuffle过程是MapReduce的核心,也被称为奇迹发生的地方.要想理解MapReduce, Shuffle是必须要了解的.我看过很多相关的资料,但每次看完都云里雾里的绕着,很难理清大致的逻辑, ...

  5. [v]Debian类系统的有效国内源

    源文件的位置 /etc/apt/sources.list 因为测试需要,装完Debian7 后,更新为163的源,但是后来装软件时,一些软件依赖包还是装不上.后来把163源稍加改动,就好用了.163源 ...

  6. java类的访问权限

    1.解析 Java有四种访问权限, 其中三种有访问权限修饰符,分别为private,public和protected,还有一种不带任何修饰符. private: Java语言中对访问权限限制的最窄的修 ...

  7. bug管理规范

    资源来自:http://wenku.baidu.com/view/ae55b3b565ce05087632132b.html

  8. viewpager+fragment+HorizontalScrollView详细版

    XML布局 <HorizontalScrollView            android:id="@+id/hsv"            android:layout_ ...

  9. Objective-C语言控制语句

    • 分支语句• 循环语句• 跳转语句 Objective-C中的控制语句有以下几类:• 分支语句:if-else, switch• 循环语句:while, do-while, for• 与程序转移有关 ...

  10. android 应用架构随笔一(架构搭建)

    1.拷贝积累utils以及PagerTab类 2.定义BaseApplication类 3.定义BaseActivity类 4.改写MainActivity 5.定义布局文件 6.定义BaseFrag ...