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}")}
  }

}

补充

相关推荐
Java后端的Ai之路1 分钟前
微调模型成本太高,用RAG技术,低成本实现AI升级
开发语言·人工智能·python·rag·ai升级
2401_876907524 分钟前
TYPE-C插拔力过大原因与解决方法
c语言·开发语言
一个处女座的程序猿O(∩_∩)O23 分钟前
Python字典详解
开发语言·python
盖头盖31 分钟前
【Java反序列化基础】
java
一个处女座的程序猿O(∩_∩)O32 分钟前
Go语言Map值不可寻址深度解析:原理、影响与解决方案
开发语言·后端·golang
极客先躯1 小时前
高级java每日一道面试题-2025年7月15日-基础篇[LangChain4j]-如何集成国产大模型(如通义千问、文心一言、智谱 AI)?
java·人工智能·langchain·文心一言·异常处理·密钥管理·参数调优
追随者永远是胜利者1 小时前
(LeetCode-Hot100)226. 翻转二叉树
java·算法·leetcode·职场和发展·go
hwtwhy1 小时前
【情人节特辑】C 语言实现浪漫心形粒子动画(EasyX 图形库)
c语言·开发语言·c++·学习·算法
芒克芒克2 小时前
深入浅出Java线程池(一)
java·开发语言