7-9 身份证排序(10 分)

简介: 7-9 身份证排序(10 分)

身份证号码共 18 位,其中第 7 到 14 位是出生日期。编写程序,输入 n(n<20)个身份证号 码,根据其中出生日期按年龄从大到小排序后输出。其中要求自定义函数 int birthday(char s[ ]),其功能是从一个身份证信息 s 中生成整数的出生日期并返回。 输入格式: 先输入 n,再输入 n 个身份证号码。 输出格式: 按年龄从大到小排序后输出身份证号码。 输入样例: 在这里给出一组输入。

例如:

3

330103200110121513

330602199007191214

330104200106111313

输出样例: 在这里给出相应的输出。

例如:

330602199007191214

330104200106111313

330103200110121513

#include<stdio.h>
#define MAX 10001 
int birthday(char s[])
{ int i,day=0;
 for(i=6;i<14;i++)
{ day=day*10+s[i]-'0';}
 return day;
}
int main()
{ char str[MAX][19],*pstr[MAX],*temp;
 int n,i,j;
scanf("%d",&n); getchar();
for(i=0;i<n;i++) pstr[i]=str[i]; //pstr 数组分别指向 n 个串
for(i=0;i<n;i++)
 scanf("%s",pstr[i]);//输入身份证信息
for(i=0;i<n;i++)//冒泡法排序
for(j=0;j<n-i-1;j++)
if(birthday(pstr[j])>birthday(pstr[j+1]))
{temp=*(pstr+j); *(pstr+j)=*(pstr+j+1); *(pstr+j+1)=temp; }
for(i=0;i<n;i++) //输出结果
printf("%s\n",pstr[i]);
return 0 ;
}


相关文章
|
1月前
|
存储 算法 搜索推荐
百万考生分数如何排序 - 计数排序
百万考生分数如何排序 - 计数排序
33 0
|
1月前
|
JavaScript
身份证号码自动判定出生年月及性别年龄
身份证号码自动判定出生年月及性别年龄
16 0
|
1月前
身份证排序问题
身份证排序问题
|
10月前
|
机器学习/深度学习 存储 算法
算法训练Day25|216.组合总和III● 17.电话号码的字母组合
算法训练Day25|216.组合总和III● 17.电话号码的字母组合
成绩排序 给出班里某门课程的成绩单,请你按成绩从高到低对成绩单排序输出,如果有相同分数则名字字典序小的在前。
成绩排序 给出班里某门课程的成绩单,请你按成绩从高到低对成绩单排序输出,如果有相同分数则名字字典序小的在前。
495 0
|
10月前
7-3 通讯录排序(20分)
输入n个朋友的信息,包括姓名、生日、电话号码,本题要求编写程序,按照年龄从大到小的顺序依次输出通讯录。题目保证所有人的生日均不相同。
107 0
【每日一题Day11】LC1773统计匹配检索规则的物品数量
给你一个数组 items ,其中 items[i] = [typei, colori, namei] ,描述第 i 件物品的类型、颜色以及名称。
42 0
Day25——组合总和III、电话号码的字母组合
Day25——组合总和III、电话号码的字母组合
67 0
PTA 1031 查验身份证 (15 分)
一个合法的身份证号码由17位地区、日期编号和顺序编号加1位校验码组成。校验码的计算规则如下:
170 0
|
iOS开发
LeetCode每日一题——1773. 统计匹配检索规则的物品数量
给你一个数组 items ,其中 items[i] = [typei, colori, namei] ,描述第 i 件物品的类型、颜色以及名称。
73 0