zoukankan      html  css  js  c++  java
  • Java实现 蓝桥杯VIP 算法提高 身份证排序

    算法提高 身份证排序
    时间限制:1.0s 内存限制:256.0MB
    问题描述
      安全局搜索到了一批(n个)身份证号码,希望按出生日期对它们进行从大到小排序,如果有相同日期,则按身份证号码大小进行排序。身份证号码为18位的数字组成,出生日期为第7到第14位
    输入格式
      第一行一个整数n,表示有n个身份证号码
      余下的n行,每行一个身份证号码。
    输出格式
      按出生日期从大到小排序后的身份证号,每行一条
    样例输入
    5
    466272307503271156
    215856472207097978
    234804580401078365
    404475727700034980
    710351408803093165
    样例输出
    404475727700034980
    234804580401078365
    215856472207097978
    710351408803093165
    466272307503271156
    数据规模和约定
      n<=100000

    import java.io.BufferedReader;
    import java.io.IOException;
    import java.io.InputStreamReader;
    import java.io.OutputStreamWriter;
    import java.io.PrintWriter;
    import java.util.ArrayList;
    import java.util.Collections;
    import java.util.Comparator;
    
    
    public class 身份证排序 {
    	static Comparator<String> c = new Comparator<String>() {
    		public int compare(String s1, String s2) {
    			String t1 = s1.substring(6,14);
    			String t2 = s2.substring(6,14);
    			if(!t1.equals(t2)){
    				return t2.compareTo(t1);
    			}
    			else return s2.compareTo(s1);
    			
    		}
    	};
    	public static void main(String[] args) throws IOException {
    //		Scanner sc = new Scanner(System.in);
    		BufferedReader re = new BufferedReader(new InputStreamReader(System.in));
    		int n = Integer.parseInt(re.readLine());
    		ArrayList<String> str = new ArrayList<String>();
    		PrintWriter pt = new PrintWriter(new OutputStreamWriter(System.out) {
    			@Override
    			public void write(int b) throws IOException {
    				// TODO Auto-generated method stub
    				
    			}
    		});
    		for(int i=0; i<n; i++){
    			String s = re.readLine();
    			str.add(s);
    		}
    		re.close();
    		
    		Collections.sort(str, c);
    
    		for(int i=0; i<str.size(); i++){
    			pt.println(str.get(i));
    		}
    		pt.flush();
    		pt.close();
    	}
    	
    
    }
    
    
  • 相关阅读:
    回文自动机(PAM) 学习笔记
    UOJ#103. 【APIO2014】Palindromes PAM模板题
    UOJ#348. 【WC2018】州区划分
    STL 抄袭笔记
    ZJOI2019Day1 游记
    UOJ#370. 【UR #17】滑稽树上滑稽果 动态规划
    UOJ#24. 【IOI2014】Rail 交互题
    UOJ#373. 【ZJOI2018】线图 搜索,树哈希,动态规划
    UOJ#75. 【UR #6】智商锁 随机化算法 矩阵树定理
    AtCoder Grand Contest 031 (AGC031) D
  • 原文地址:https://www.cnblogs.com/a1439775520/p/13078388.html
Copyright © 2011-2022 走看看