身份证排序

该博客主要讨论如何对一组身份证号码进行排序,首先按照出生日期从大到小的顺序,若出生日期相同则按身份证号码本身排序。题目提供了一个样例输入和输出,展示了一种可能的解决方案。
摘要由CSDN通过智能技术生成

身份证排序
问题 H: 身份证排序
  
 "
时间限制    1 秒/Second(s)    内存限制    128 兆字节/Megabyte(s)
提交总数    392    正确数量    282
裁判形式    标准裁判/Standard Judge    我的状态    尚未尝试
难度        分类标签    结构体 字符串 排序
题目描述
安全局搜索到了一批(n个)身份证号码,希望按出生日期对它们进行从大到小排序,
如果有相同日期,则按身份证号码大小进行排序。身份证号码为18位的数字组成,出生日期为第7到第14位 

输入
第一行一个整数n,表示有n个身份证号码 
余下的n行,每行一个身份证号码。 

输出
按出生日期从大到小排序后的身份证号,每行一条 


样例输入复制
5
466272307503271156
215856472207097978
234804580401078365
404475727700034980
710351408803093165
样例输出复制
404475727700034980
234804580401078365
215856472207097978
710351408803093165
466272307503271156
提示
n< =100000 

#include<bits/stdc++.h>
#define MAX  100001 
using namespace std ;

int n ; 
string a[MAX];
//排序规则 获取两个字符串 
bool cmp(string str1 ,string str2){
	string 
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值