Scala身份证上的秘密以及Map的遍历

Scala 复制代码
object test {
  def main(args: Array[String]): Unit = {
    val id ="42032220080903332x"
    //1.生日是?
    //字符串截取
    val birthday =id.substring(10,14) //不包括终点下标
    println(birthday)
    val year =id.substring(6,10)  //
    println(year)
    //性别:倒数第2位
    //如果是奇数:boy,偶数:girl
    val gender = id.charAt(16)
    println(gender)
    if(gender.toInt % 2 ==0) {
      println("性别是:女生")
    }
    else {
      println("性别是:男生")
    }
    //前两位表示省份
    val province = id.substring(0,2).toInt
    val m1 = Map((41,"河南"),(42,"湖北"),(43,"湖南"),(44,"广东"))
    println(s"籍贯是:${m1.get(province)}")

    //验证身份证号是否合法
    //每一位的积重
    val weights =Array(7,9,10,5,8,4,2,1,6,3,7,9,10,5,8,4,2)
    val checkCodes ="10x98765432"
    var sum = 0
    for (i <- 0 to 16){
      sum += id(i).toInt * weights(i)
    }
    if(id.charAt(17)==checkCodes.charAt(sum%11)){
      println(s"校检成功")
    }else{
      println(s"校检失败")
    }
    val str1 =
      """
        |静夜思
        |李白
        |床前明月光
        |疑是地上霜
        |"""
  }

}

map的遍历

Scala 复制代码
import scala.io.Source

object test32 {
  def main(args: Array[String]): Unit = {
    val content = Source.fromFile("1.text").mkString
    println(content)
    //把字符串中的每个单词,拆出来
    //正则表达式
    //\\W+:大学字符串表示:非字(不是一个的字符。例如:空格 逗号 句号 换行...)
    //+:一个或者多个
    val arr =content.split("\\W+")  //
    arr.foreach(println)
    //如果有一个字符串组:
    val arr1 =Array("thank","you","very","much","thank","very")
    val m1 =scala.collection.mutable.Map[String,Int]()
    arr1.foreach(word =>{
      //检查是否出现过?
      if (m1.contains(word)){
        //把票数+1
        m1(word) += 1
      }else {
        //票数为1
        2
      }
    })
    //对于m1,它是一个Map(thank:10,is:5),现在需要对它进行排序,把出现次数最多的放在最前面,然后再输出
    m1.foreach{case (word,cishu) => println(s"${word}:${cishu}")}
  }

}

补充

相关推荐
葵续浅笑2 分钟前
LeetCode - 杨辉三角 / 二叉树的最大深度
java·数据结构·算法·leetcode
装不满的克莱因瓶12 分钟前
【Java架构师】各个微服务之间有哪些调用方式?
java·开发语言·微服务·架构·dubbo·restful·springcloud
杨筱毅18 分钟前
【穿越Effective C++】条款13:以对象管理资源——RAII原则的基石
开发语言·c++·effective c++
N 年 后24 分钟前
cursor和传统idea的区别是什么?
java·人工智能·intellij-idea
CodeLongBear41 分钟前
从Java后端到Python大模型:我的学习转型与规划
java·python·学习
Miraitowa_cheems1 小时前
LeetCode算法日记 - Day 94: 最长的斐波那契子序列的长度
java·数据结构·算法·leetcode·深度优先·动态规划
Zz_waiting.1 小时前
统一服务入口-Gateway
java·开发语言·gateway
ada7_1 小时前
LeetCode(python)——49.字母异位词分组
java·python·leetcode
DyLatte1 小时前
AI时代的工作和成长
java·后端·程序员
四维碎片1 小时前
【Qt】大数据量表格刷新优化--只刷新可见区域
开发语言·qt