Scala学习(四)练习
|
映射和元组&练习 |
1. 设置一个映射,其中包含你想要的一些装备,以及它们的价格。然后构建另一个映射,采用同一组键,但在价格上打9折
映射代码如下:
object HelloScala{
def main(args: Array[String]): Unit = {
val map=Map("Computer"->3000,"Iphone"->2000,"Cup"->10)
val fold=for((k,v)<-map) yield (k,v*0.9)
fold.foreach(println)
}
}
运行结果:
(Computer,2700.0)
(Iphone,1800.0)
(Cup,9.0)
2. 编写一段程序,从文件中读取单词。用一个可变映射来清点每一个单词出现的频率。读取这些单词的操作可以使用java.utiI.Scanner:
val in=new java.util.Scanner(new java.io.File("myfile.txt"))
while (in.hasNext()) 处理in .next()
最后,打印出所有单词和它们出现的次数
首先,新建一个file文件,文件名为:file,文件内容如下:
Hello Hello
World Hello Scala
单词统计代码如下:
object HelloScala{
def main(args: Array[String]): Unit= {
val in=new Scanner(new File("src/file"))
val maps=new HashMap [String,Int]
var key:String=null
while(in.hasNext()){
key=in.next()
}
maps.foreach(println);
}
}
运行结果如下:
(Hello,3)
(Scala,1)
(World,1)
3. 重复前一个练习,这次用不可变的映射
不可变映射代码如下:
object HelloScala{
def main(args: Array[String]): Unit= {
val in=new Scanner(new File("src/file"))
行会报错
var key:String=null
while(in.hasNext()){
key=in.next()
maps+=(key->(maps.getOrElse(key, 0)+1))
}
maps.foreach(println)
}
}
运行结果:
(Hello,3)
(Scala,1)
(World,1)
4. 重复前一个练习,这次用已排序的映射,以便单词可以按顺序打印出来
使用SortedMap映射代码如下:
object HelloScala{
def main(args: Array[String]): Unit= {
val in=new Scanner(new File("src/file"))
var sortMap=SortedMap[String,Int]()
var key:String=null
while(in.hasNext()){
key=in.next()
sortMap+=(key->(sortMap.getOrElse(key, 0)+1))
}
sortMap.foreach(println)
}
}
运行结果:
(Hello,3)
(Scala,1)
(World,1)
5. 重复前一个练习,这次用java.utiI.TreeMap并使之适用于Scala API
程序代码如下:
object HelloScala{
def main(args: Array[String]): Unit= {
val in=new Scanner(new File("src/file"))
val map:Map[String,Int]=new TreeMap[String,Int]
var key:String=null
while(in.hasNext()){
key=in.next()
}
map.foreach(println)
}
}
运行结果如下:
(Hello,3)
(Scala,1)
(World,1)
6. 定义一个链式哈希映射,将"Monday"映射java.utiI.Calendar.MONDAY,依此类推加入其他日期。展示元素是以插入的顺序被访问的
链式哈希映射基本使用;
object HelloScala{
def main(args: Array[String]): Unit= {
val map=new LinkedHashMap[String,Int]
map+=("Monday"->Calendar.MONDAY)
map+=("Tuesday"->Calendar.TUESDAY)
map+=("Thursday"->Calendar.THURSDAY)
map+=("Wednesday"->Calendar.WEDNESDAY)
map+=("Friday"->Calendar.FRIDAY)
map+=("Saturday"->Calendar.SATURDAY)
map+=("Sunday"->Calendar.SUNDAY)
map.foreach(println)
}
}
运行结果:
(Monday,2)
(Tuesday,3)
(Thursday,5)
(Wednesday,4)
(Friday,6)
(Saturday,7)
(Sunday,1)
7. 打印出所有Java系统属性的表格,类似这样:
java.runtime.name | Java (TM) SE Runtime Environment
sun.boot.library.path | /home/apps/jdk1.6.0_21/jre/lib/i386
java.vm.version |17.0-b16
java.vm.vendor | Sun Microsystems Inc.
java.vendor.url | http://java.sun*com/
path.separator |:
java.vm.name | Java HotSpot (TM) Server VM
你需要找到最长键的长度才能正确地打印出这张表格
属性转ScalaMap:
object HelloScala{
def main(args: Array[String]): Unit= {
val props:scala.collection.Map[String,String]=System.getProperties()
val keys=props.keySet
val keylens=for(i<-keys) yield i.length()
val keymaxlen=keylens.max
for(key <- keys){
print(key)
print(" "*(keymaxlen-key.length()))
print("|")
println(props(key))
}
}
}
运行结果:
java.runtime.name |Java(TM) SE Runtime Environment
sun.boot.library.path |F:\Tools\DevelopTool\Jre1.7\bin
java.vm.version |24.72-b04
java.vm.vendor |Oracle Corporation
java.vendor.url |http://java.oracle.com/
path.separator |;
java.vm.name |Java HotSpot(TM) Client VM
file.encoding.pkg |sun.io
8. 编写一个函数minmax(values: Array[lnt]),返回数组中最小值和最大值的对偶
程序代码如下:
object HelloScala{
def main(args: Array[String]): Unit= {
val array=Array(1,2,3,4,5)
var tuple:(Int,Int)=minmax(array)
println(tuple._1+" "+tuple._2)
}
def minmax(arr:Array[Int])={
(arr.min,arr.max)
}
}
运行结果:
1 5
9. 编写一个函数lteqgt(values: Array[lnt],v:Int),返回数组中小于v、等于v和大于V的数量,要求三个值一起返回
程序代码如下:
object HelloScala{
def main(args: Array[String]): Unit= {
val array=Array(1,1,2,2,3,3,4,5,6)
val tuple:(Int,Int,Int)=iteqgt(array,3)
的数量:"+tuple._1)
的数量:"+tuple._2)
的数量:"+tuple._3)
}
def iteqgt(arr:Array[Int],v:Int)={
val buf=arr.toBuffer
(buf.count(_ < v),buf.count(_ == v),buf.count(_ >= v))
}
}
运行结果:
的数量:4
的数量:2
的数量:5
10. 当你将两个字符串拉链在一起,比如"Hello".zip("World"),会是什么结果,想出一个讲得通的用例
程序代码:
object HelloScala{
def main(args: Array[String]): Unit= {
val tuple="Hello".zip("World")
tuple.toMap
tuple.foreach(println)
}
}
运行结果:
(H,W)
(e,o)
(l,r)
(l,l)
(o,d)
在Scaladoc的StringOps中的zip方法定义如下:
def zip[B] (that: GenIterable[B]) : String[(A, B)]
GenIterable是可遍历对象需要包含的trait,对于String来说,它是可遍历的。但是它的遍历是遍历单个字母。 所以拉链就针对每个字母来进行
如果,您认为阅读这篇博客让您有些收获,不妨点击一下右下角的【推荐】。
如果,您希望更容易地发现我的新博客,不妨点击一下左下角的【关注我】。
如果,您对我的博客所讲述的内容有兴趣,请继续关注我的后续博客,我是【Sunddenly】。本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留追究法律责任的权利。
Scala学习(四)练习的更多相关文章
- Scala学习四——映射和数组
一.本章要点 Scala有十分易用的语言来创建,查询和遍历映射 你需要从可变和不可变的映射中做出选择 默认情况下,你得到的是一个哈希映射,不过你也可以指明要树形映射 你可以很容易地在Scala映射和J ...
- Scala学习(四)---映射和元组
映射和元组 摘要: 一个经典的程序员名言是:"如果只能有一种数据结构,那就用哈希表吧".哈希表或者更笼统地说映射,是最灵活多变的数据结构之一.映射是键/值对偶的集合.Scala有一个通用的叫法:元组, ...
- 【Todo】【读书笔记】大数据Spark企业级实战版 & Scala学习
下了这本<大数据Spark企业级实战版>, 另外还有一本<Spark大数据处理:技术.应用与性能优化(全)> 先看前一篇. 根据书里的前言里面,对于阅读顺序的建议.先看最后的S ...
- 基于.net的分布式系统限流组件 C# DataGridView绑定List对象时,利用BindingList来实现增删查改 .net中ThreadPool与Task的认识总结 C# 排序技术研究与对比 基于.net的通用内存缓存模型组件 Scala学习笔记:重要语法特性
基于.net的分布式系统限流组件 在互联网应用中,流量洪峰是常有的事情.在应对流量洪峰时,通用的处理模式一般有排队.限流,这样可以非常直接有效的保护系统,防止系统被打爆.另外,通过限流技术手段,可 ...
- Scala学习资源
Scala学习资源: Scala官方网站:http://www.scala-lang.org/ Scala github:https://github.com/scala/scala Twitter ...
- TweenMax动画库学习(四)
目录 TweenMax动画库学习(一) TweenMax动画库学习(二) TweenMax动画库学习(三) Tw ...
- 机器学习(三)--- scala学习笔记
Scala是一门多范式的编程语言,一种类似Java的编程语言,设计初衷是实现可伸缩的语言.并集成面向对象编程和函数式编程的各种特性. Spark是UC Berkeley AMP lab所开源的类Had ...
- SVG 学习<四> 基础API
目录 SVG 学习<一>基础图形及线段 SVG 学习<二>进阶 SVG世界,视野,视窗 stroke属性 svg分组 SVG 学习<三>渐变 SVG 学习<四 ...
- 【Scala】Scala学习资料
Scala学习资料 java 树形 分类器_百度搜索 决策树分类器-Java实现 - CSDN博客 KNN分类器-Java实现 - CSDN博客 学习:java设计模式—分类 - 飞翔荷兰人 - 博客 ...
随机推荐
- Apktool(1)——Apktool的安装
Apktool是google提供的apk的编译工具,有了它就可以做很多事情.比如获取apk的源码,apk汉化,对手机rom包做一些美化. 首先来看看apktool的安装(配置): 以下内容主要翻译字A ...
- JS数组分组
//1.找出数组中相同的元素 getRepeatNum(arr) { let obj = {}; for (let i = 0, len = arr.length; i < len; i++) ...
- C# 异步编程4 async与await 异步程序开发
随着C#异步程序开发系列的深入,你会发现编写异步程序越发简单.事物的发展就是这样的规律,从简单到复杂再到简单. 在C# 5.0中我们可以通过async与await关键字实现快捷的异步程序开发,如下: ...
- SQL Server 2005详细安装过程及配置
说明:个人感觉SQL Server 2005是目前所有的SQL Server版本当中最好用的一个版本了,原因就是这个版本比起其它版本来说要安装简单,操作简便,只可惜这个版本只能在Windows7或者低 ...
- Centos 下添加开机自启动服务和脚本
最近刚玩Centos7的系统,跟Centos6还是很多方面有改变的,这里记录一下怎么在Centos7下添加开机自启动脚本和服务的方法. 1.添加开机自启服务 我这里以docker 服务为例,设置如下两 ...
- Fedora 28 打印机配置 ( HP pro 1136M ,基于Windows 打印服务器使用 smb 协议)
Fedora 28 本身是没有打印服务的.我们需要安装下列软件: System-Config-Printer Common Unix Printing System - CUPS hplip.x86_ ...
- 【PAT】B1085 PAT单位排行(25 分)(c++实现)
终于做的有点眉目了,今天学习了一点stl的皮毛,解题瞬间变容易了 下边开始分析本题 这道题如果用纯c解决实在太麻烦,试了半天两个超时,果断放弃,还是用map方便: 我的方法与柳神的方法是有区别的,我只 ...
- python基本数据类型 数字 和 字符串
一.数字 int type可以查看数据类型 将字符串转换为数字: a=" b=int(a) print(type(a)) 以十六进制或者八进制或者二进制的形式转换为十进制: num ...
- 17秋 软件工程 团队第五次作业 Alpha Scrum11
17秋 软件工程 团队第五次作业 Alpha Scrum11 今日完成的任务 世强:管理员头像图片上传和显示逻辑处理,活动添加及上传图片: 港晨:完成Web界面前后端对接: 树民:标准化后端接口格式: ...
- golang的json序列化问题
首先看一段代码: package main import ( "encoding/json" "fmt" ) type Result struct { //st ...