• 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();
    	}
    	
    
    }
    
    
  • 相关阅读:
    MEF(Managed Extensibility Framework ) 可控扩展框架
    如何打开ASP.NET Configuration页面
    [转贴]技术的乐趣
    ORM工具介绍 NHibernate, EntitySpaces, and LLBLGen Pro 功能分析
    Linq to SQL 学习路线图
    [转贴]What is AntiPattern 什么是反模式
    Master Data Management(MDM)主数据管理
    Introducing Unity Application Block
    C#2.0 C#3.0 语言特性
    javascript声明数组三种方式
  • 原文地址:https://www.cnblogs.com/a1439775520/p/13078962.html
Copyright © 2020-2023  润新知