第1关:List 列表的使用
编程要求
仔细阅读右侧编辑区内给出的代码框架及注释,在 Begin-End 间编写程序代码,连接两个列表并对数据去重,具体要求如下:
接收给定的多行数据(例:4 \n 56 \n 5 \n -10 \n 10,其中第一个数代表列表长度,其余数代表具体值,\n 仅用来说明前一个数与另一个数之间是换行,实际数据中并没有);
将接收到的数据添加进列表,并把该列表连接到列表 list 之后;
对连接后的集合数据去重,并输出去重后的集合。
测试说明
平台将使用测试集运行你编写的程序代码,若全部的运行结果正确,则通关。
例:
测试输入:
4
3
4
6
2
预期输出:
List(2, 4, 5, 3, 6)
开始你的任务吧,祝你成功!
代码1
import scala.collection.mutable.ArrayBuffer import scala.io.StdIn object ForDemo { def main(args: Array[String]): Unit = { // 创建集合list val list =List(2,4,5) // 接收给定的第一个数据 val n=StdIn.readInt() // 创建数组 var arr = new ArrayBuffer[Int]() // 将数据添加到数组 for(x<-1 to n){ var line =StdIn.readLine() var line1=line.toInt arr.insert(x-1,line1) } // 将数组转为列表 val list1= arr.toList // 请在 Begin-End 间编写代码 /********** Begin **********/ // 连接两个列表 val combinedList = list ++ list1 // 去重 val distinctList = combinedList.distinct // 输出结果 println(distinctList) /********** End **********/ } }第2关:Set 集合的使用
编程要求
仔细阅读右侧编辑区内给出的代码框架及注释,在 Begin-End 间编写程序代码,求两个集合的交集,具体要求如下:
接收给定的多行数据(例:4 \n 56 \n 5 \n -10 \n 10,其中第一个数代表集合长度,其余数代表具体值,\n 仅用来说明前一个数与另一个数之间是换行,实际数据中并没有);
将接收到的数据添加进集合,并输出该集合与给定集合 set 的交集。
测试说明
平台将使用测试集运行你编写的程序代码,若全部的运行结果正确,则通关。
例:
测试输入:
4
3
4
6
2
预期输出:
List(2, 4, 5, 3, 6)
开始你的任务吧,祝你成功!
代码2
import scala.collection.mutable.ArrayBuffer import scala.io.StdIn object ForDemo { def main(args: Array[String]): Unit = { val set = Set(2,3,7,8) // // 请在 Begin-End 间编写代码 // /********** Begin **********/ val n=StdIn.readInt() // 创建动态数组,ArrayBuffer var arr = new ArrayBuffer[Int]() // 利用循环将数据添加到数组,使用循环是最直观和简洁的方式来处理多行输入 for(x<- 1 to n){ val element = StdIn.readInt() arr += element } // 将数组转为列表 val set1= arr.toSet print("两个集合的交集是:") print(set.intersect(set1)) /********** End **********/ } }第3关:Map 映射的使用
编程要求
仔细阅读右侧编辑区内给出的代码框架及注释,在 Begin-End 间编写程序代码,统计给定字符串中每个单词出现的次数,具体要求如下:
接收给定的一行字符串(例:hello-hello,hi,job-hi,...,依次切割英文逗号和“-”,可以得到每个单词);
统计各单词出现的次数。
测试说明
平台将使用测试集运行你编写的程序代码,若全部的运行结果正确,则通关。
例:
测试输入:
hello-hello,hi,job-hi
预期输出:
单词: hi, 个数 1
单词: hello, 个数 2
开始你的任务吧,祝你成功!
代码3
import scala.io.StdIn object ForDemo { def main(args: Array[String]): Unit = { // 请在 Begin-End 间编写代码 /********** Begin **********/ // 统计给定字符串中各单词出现的次数 val str=StdIn.readLine()//读取一行输入字符串 val words=str.split("[-|,]")//使用正则表达式分割字符串,按逗号和连字符分割,正则表达式中|:表示“或”。 split返回一个数组 //groupBy 是用于将集合中的元素按照指定的规则分组。 //identity 是一个预定义的函数,表示“原样返回输入值”。 //mapValues 是 Scala Map 中的一个方法,用于对 Map 中的每个值进行转换。 //_.length 表示“获取数组的长度”。 //mapValues(_.length),它会将每个值(数组)转换为其长度 val counts=words.groupBy(identity).mapValues(_.length) counts.foreach{case(word,count) => println(s"单词: $word, 个数 $count")}//集合中的每个元素是一个键值对(word 和 count),分别表示单词和对应的计数。 /********** End **********/ } }第4关:元组的使用
编程要求
仔细阅读右侧编辑区内给出的代码框架及注释,在 Begin-End 间编写程序代码,统计元组中所有整数的积,具体要求如下:
根据给定数据创建元组(给定数据为:23,hello,3,33,hi,map,51);
统计元组中所有整数的积。
测试说明
平台将使用测试集运行你编写的程序代码,若全部的运行结果正确,则通关。
例:
测试输入:
无
预期输出:
整数积为: 116127
开始你的任务吧,祝你成功!
代码4
object ForDemo { def main(args: Array[String]): Unit = { // 请在 Begin-End 间编写代码 /********** Begin **********/ // 统计元组中所有整数的积 val t=(23,"hello",3,33,"hi","map",51)//val(不可变变量) var product=1//var(可变变量) t.productIterator.foreach{ case num: Int => product *= num // 如果是整数,累乘} case _ => // 忽略其他类型 } println(s"整数积为: $product") /********** End **********/ } }