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();
    	}
    	
    
    }
    
    
  • 相关阅读:
    Windows 7 任务计划程序
    '7z' 不是内部或外部命令,也不是可运行的程序
    [转]国外人气最旺的软件测试网站
    AutoIT查找文件内容并修改保存
    BUG 太少
    excel表格数据导入sqlserver数据库
    RoR常见问题
    [转]漫画:程序员的一生
    [转]RubyInstaller: Getting Started with Rails and SQLite3
    [转]C#多线程学习(一) 多线程的相关概念
  • 原文地址:https://www.cnblogs.com/a1439775520/p/13078387.html
Copyright © 2011-2022 走看看