7-5 jmu-Java-02基本语法-03-身份证排序 --笔记篇 简洁清晰

题目

输入n,然后连续输入n个身份证号。

然后根据输入的是sort1还是sort2,执行不同的功能。输入的不是sort1或sort2,则输出exit并退出。

输入sort1,将每个身份证的年月日抽取出来,按年-月-日格式组装,然后对组装后的年-月-日升序输出。

输入sort2,将所有身份证按照里面的年月日升序输出。

注意:处理输入的时候,全部使用Scanner的nextLine()方法,以免出错。

c 复制代码
输入样例:
6
410425198309308225
320203197206115011
431227196108033146
330226196605054190
34080019810819327X
320111197112301539
sort1
sort2
e

输出样例:
1961-08-03
1966-05-05
1971-12-30
1972-06-11
1981-08-19
1983-09-30
431227196108033146
330226196605054190
320111197112301539
320203197206115011
34080019810819327X
410425198309308225
exit

代码

java 复制代码
import java.util.*;
class cp implements Comparator<String>{
    @Override
    public int compare(String o1, String o2) {
        return o1.substring(6,14).compareTo(o2.substring(6,14));
    }
}

public class Main {
    public static void main(String args[]) {
        Scanner in = new Scanner(System.in);
        int n=in.nextInt();
        in.nextLine();
        ArrayList<String> p=new ArrayList<>();
        ArrayList<String> p1=new ArrayList<>();
        while (n>0){
            String l=in.nextLine();
            p.add(l);
            n--;
        }
        while (in.hasNext()){
            String ll=in.nextLine();
            if (ll.equals("sort1"))
            {
                for(String lll:p)
                    p1.add(lll.substring(6,10)+'-'+lll.substring(10,12)+'-'+lll.substring(12,14));
                Collections.sort(p1);
                for (String i:p1)
                    System.out.println(i);
            }
            else if (ll.equals("sort2")){
                p.sort(new cp());
                for (String i:p)
                    System.out.println(i);
            }
            else {
                System.out.println("exit");
                break;
            }
        }
    }
}

笔记

这段代码主要实现了两个排序功能,一个是按照字符串的子串进行排序,另一个是按照字符串的特定位置进行排序。

这段代码主要涉及到了以下知识点:

1.字符串的子串操作:substring方法用于获取字符串的子串。

2.集合的排序和反转:Collections.sort和Collections.reverse方法用于对集合进行排序和反转。

3.自定义比较器:定义了一个实现了Comparator接口的类cp,并重写了compare方法,用于自定义比较规则。

相关推荐
Hanson,几秒前
SpringBoot前后端分离框架中,在请求头加入签名
java·spring boot·后端
不懂的浪漫1 分钟前
一次设备映射缓存设计:用多索引 Map 把高频查询从遍历变成直接命中
java·算法·spring·缓存
好家伙VCC2 分钟前
# React发散创新:从状态管理到自定义Hook的极致实践与性能优化在现代前端开发
java·javascript·python·react.js·性能优化
eLIN TECE5 分钟前
Redis重大版本整理(Redis2.6-Redis7.0)
java·数据库·redis
apollowing6 分钟前
启发式算法WebApp实验室:从搜索策略到群体智能的能力进阶(三十)
算法·启发式算法·web app
花千树-0109 分钟前
两行注解把企业 RPC 接口变成 AI 工具
java·rpc·langchain·react·function call·ai agent·mcp
田野追逐星光9 分钟前
C++继承 -- 讲解超详细(上)
c++·算法
迷藏49410 分钟前
**绿色AI:用Python构建节能型机器学习模型的实践与优化策略**在人工智能飞速发展的今天,模型训练和
java·人工智能·python·机器学习
juniperhan14 分钟前
Flink 系列第13篇:Flink 生产环境中的并行度与资源配置
java·大数据·数据仓库·分布式·flink
Foreer黑爷17 分钟前
Spring MVC原理与源码:从请求到响应的全流程解析
java·spring·mvc