scala编程--计算级数&统计学生成绩

2023-05-16

目录

  • 案例1:计算级数
    • 1.1 案例要求
    • 1.2 实现代码
  • 案例2:统计学生成绩
    • 1.1 案例要求
    • 1.2 实现代码
  • 总结


案例1:计算级数

1.1 案例要求

级数计算函数实现较为简单,这里不再赘述,注意返回值直接用变量名返回,无需调用return;
在输入时,使用readInt函数从控制台输入要求的级数,调用函数打印计算结果。

1.2 实现代码

object demo2 {
  //计算级数函数
  def Series(n:Int) = {
    var sum = 0.0
    var i = 1.0
    while (sum < n) {
      sum += (i+1)/i
      i += 1
    }
    //返回值:无需使用return,直接返回
    sum
  }

  def main(args: Array[String]): Unit = {
    //读取用户输入
    var n = readInt()
    var sum = Series(n)
    //打印输出:保留6位小数
    printf("%.6f",sum)
  }
}

案例2:统计学生成绩

1.1 案例要求

1)读取学生成绩:将学生成绩写入TXT文件,通过读取TXT文件将学生成绩放入到数组中;
注意:读取编码格式;

2)求成绩平均值:定义aver函数,实现求平均值;
注意:有现成的最值求值函数,无需自己编写实现;

3)统计学生成绩:将数组当中的各科成绩读取到缓冲数组中,对缓冲数组进行求最值平均的操作;
注意:使用缓冲数组进行操作,因为其为可变数组,便于操作;

1.2 实现代码

object demo3 {
  def main(args: Array[String]): Unit = {
    var file = readTxt("C:\\score.txt")
    static(file)

    //对男生和女生成绩做分别统计
    var file_males = file.toBuffer
    var file_females = file.toBuffer
    for(i <- 1 until file.length){
      var row = file(i)
      if (row.split('\t')(1) != "male"){
        file_males -= row
      }
      if (row.split('\t')(1) != "female"){
        file_females -= row
      }
    }

    println("males")
    static(file_males.toArray)

    println("females")
    static(file_females.toArray)
  }

  def static(file:Array[String])={
    //缓冲数组
    var course1 = ArrayBuffer[String]()
    var row = file(0).split('\t')
    for(i <- 2 until row.length){
      course1 += row(i)
    }
    val course = course1.toArray
    var data = dim2B(course.length)
    for(i <- 1 until file.length){
      row = file(i).split('\t')
      for(j <- 2 until row.length){
        data(j-2) += row(j).toDouble
      }
    }

    //在输出时,使用prinf的%-8s来给每个元素设置固定大小位置,实现数据打印上下对齐
    printf("%-8s\t%-8s\t%-8s\t%-8s\n","course","average","min","max")
    for(i <- 0 until course.length){
      printf("%-8s\t%-8s\t%-8s\t%-8s\n",course(i),aver(data(i).toArray),data(i).toArray.min,data(i).toArray.max)
    }
  }

  //二维数组
  def dim2B(rows : Int)={
    val d2  = new Array[ArrayBuffer[Double]](rows)
    for (k <-0 until rows ) {
      d2(k) = new ArrayBuffer[Double]()
    }
    d2
  }

  //读取文件
  def readTxt(filePath: String) ={
    //以指定的UTF-8字符集读取文件,第一个参数可以是字符串或者是java.io.File
    val source = Source.fromFile(filePath, "UTF-8")
    //将所有行放到数组中
    val lines = source.getLines().toArray
    source.close()
    lines
  }

  //数组求最大值最小值有现成函数调用,无需编写
  def max(a:Array[Double]):Double={
    var res = 0.0
    for(i <- a){
      if (i>res){
        res = i
      }
    }
    res.formatted("%.2f").toDouble
  }

  def min(a:Array[Double]):Double={
    var res = 100.0
    for(i <- a){
      if (i < res){
        res = i
      }
    }
    res.formatted("%.2f").toDouble
  }

  def aver(a:Array[Double]):Double={
    var res = 0.0
    for(i <- a){
      res = res + i
    }
    (res/a.length).formatted("%.2f").toDouble
  }

}


总结

在输出时,使用c语言风格的printf来统一小数位数;以及使用prinf的%-8s来给每个元素设置固定大小位置,实现数据打印上下对齐!使打印结果更加美观!

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

scala编程--计算级数&统计学生成绩 的相关文章

随机推荐

  • 边缘计算节点是啥?边缘计算与CDN有什么关系?一文带你了解边缘计算节点BEC(1)

    边缘计算节点是基于CDN边缘节点构建 xff0c 覆盖全国大部分地区 xff0c 三大运营商全覆盖 将算力下沉到各城市级节点 xff0c 提供离用户更近的算力资源 那么可能有些小伙伴会问 xff0c CDN也是就近为用户提供服务 xff0c
  • 任何的Linux开发板+ADB+fastboot驱动-----真实有效!

    目录 1 xff1a ADB安装 2 xff1a fastboot驱动安装 1 xff1a ADB安装 这个可以在CSDN查 xff0c 不讲 2 xff1a fastboot驱动安装 1条消息 解决Win10 Win11 Fastboot
  • SQLite Studio如何使用的详细教程!零开始教起哦!

    目录 1 xff1a 下载安装SQLite Studio xff08 可在CSDN查找下载 xff09 2 xff1a 打开SQLite Studio 3 xff1a 使用SQLite Studio 1 xff1a 下载安装SQLite S
  • 什么是makefile?教你简单编写和使用Makefile

    什么是Makefile xff1f Makefile可以简单的理解成一个工程文件的编译规则 Makefile文件描述了Linux系统下C C 43 43 项目工程的编译规则 xff0c 它的作用是用来自动化编译C C 43 43 的项目 一
  • 《程序员面试金典(第6版)》面试题 16.14. 最佳直线(向量,C++)

    题目描述 给定一个二维平面及平面上的 N 个点列表Points xff0c 其中第i个点的坐标为Points i 61 Xi Yi 请找出一条直线 xff0c 其通过的点的数目最多 设穿过最多点的直线所穿过的全部点编号从小到大排序的列表为S
  • 制作Ubuntu启动盘并安装ros的学习笔记

    本菜鸡刚开始学习ros xff0c 之前一直用虚拟机 xff0c 但但是配置极其麻烦 xff0c 容易出现各种错误 xff0c 对新手极其不友好 亲测做一个Ubuntu的启动盘很是稳定 为了后续学习时回看 xff0c 记录一下遇到的问题以及
  • Ubuntu22.04没有ttyUSB(无法访问 ‘/dev/ttyUSB‘: 没有那个文件或目录)问题解决

    无法访问 dev ttyUSB 没有那个文件或目录 环境 xff1a ubuntu22 04 xff0c 使用需求为USB转串口 问题描述 在给串口读写权限时 xff0c 出现问题 xff1a 无法访问 dev ttyUSB0 没有那个文件
  • 光流(optical flow)基础概念以及典型算法

    光流 xff08 optical flow xff09 基础概念以及典型算法 文章目录 光流 xff08 optical flow xff09 基础概念以及典型算法什么是光流 xff1f 一 传统经典光流算法 xff1a Lucas Kan
  • PX4无人机安装问题及解决方案

    文章目录 1 git clone1 git clone fatal error2 PX4源码下载很慢 2 ROS安装1 设置密钥2 xff09 E 无法定位软件包 ros melodic desktop full3 sudo apt ins
  • 玩转k8s(四)—— 通过Service访问Pod

    我们不应该期望k8s Pod是健壮的 xff0c 而是要假设Pod中的容器很可能因为各种原因发生故障而死掉 Deployment等Controller会通过动态的创建和销毁Pod来保证应用整体的健壮性 换句话说 xff0c Pod是脆弱的
  • STM32之IO模拟串口篇

    概述 xff1a 硬件 xff1a 基于stm32f767igt6水星板开发 xff1b 软件 xff1a 使用了RT Thread实时操作系统 xff0c 两个空闲IO口 PE2用作串口TX端 xff0c 搭配一个定时器控制发送时序 xf
  • BPMN2.0 任务-脚本任务

    描述 脚本任务 script task 是自动执行的活动 当流程执行到达脚本任务时 会执行相应的脚本 脚本任务用左上角有一个小 脚本 图标的标准BPMN 2 0任务 圆角矩形 表示 脚本任务使用script与scriptFormat元素定义
  • 最短路径问题——基于Dijkstra算法和Floyd算法的最短路径问题

    目录 1 算法介绍 xff08 1 xff09 Dijkstra Algorithm xff08 迪杰斯特拉算法 xff09 xff08 2 xff09 Floyd Algorithm xff08 佛洛依德算法 xff09 xff08 3
  • 2.1.2 进程的状态与转换

    目录 知识总览 1 三种基本状态 xff08 1 xff09 运行态 xff08 Running xff09 xff08 2 xff09 就绪态 xff08 Ready xff09 xff08 3 xff09 阻塞态 xff08 Waiti
  • 合并排序与快速排序算法

    文章目录 算法介绍代码实现1 合并排序2 快速排序 总结 算法介绍 合并排序与快速排序是排序算法中常用的两种排序算法 xff0c 合并排序把数据分为两段 xff0c 从两段中逐个选最小的元素移入新数据的末尾 xff1b 快速排序是在序列中挑
  • 2进制、8进制、10进制、16进制相互转换

    文章目录 介绍1 二进制转其他进制2 八进制转其他进制3 十进制转其他进制4 十六进制转其他进制总结 介绍 百度百科 xff1a 进制也就是进位计数制 xff0c 是人为定义的带进位的计数方法 xff08 有不带进位的计数方法 xff0c
  • Hadoop学习笔记--HBase相关操作指令

    文章目录 引言0 HBase的启动与停止1 创建表2 删除表3 表的其他操作3 1 修改表结构3 2 查看表结构3 3 显示所有用户定义的表3 4 查询表是否存在3 5 查询表是否可用3 6 查询表中记录数 4 插入数据4 1 插入单条数据
  • Hadoop学习笔记--MapReduce

    文章目录 引言1 经典案例分析 xff1a WordCount1 1 Map阶段 xff1a TokenizerMapper类1 2 Reduce阶段 xff1a IntSumReduce类1 3 Driver阶段 xff1a main x
  • Hadoop学习笔记--YARN

    文章目录 引言1 YARN的优势1 1 可扩展性 xff08 Scalability xff09 1 2 可用性 xff08 Availability xff09 1 3 利用率 xff08 Utilization xff09 1 4 多租
  • scala编程--计算级数&统计学生成绩

    目录 案例1 xff1a 计算级数1 1 案例要求1 2 实现代码 案例2 xff1a 统计学生成绩1 1 案例要求1 2 实现代码 总结 案例1 xff1a 计算级数 1 1 案例要求 级数计算函数实现较为简单 xff0c 这里不再赘述