身份证验证

Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)
Total Submission(s): 1611    Accepted Submission(s): 201

Problem Description
大学时代的小Q,是一个志向远大的热血青年,欲致力于国家网络建设。长年泡在电脑密集的地区潜心钻研以互联网为传输媒介,以个人计算机为终端,旨在实现休闲、交流、获得虚拟成就的多人在线游戏。

毕业后,小Q实现了自己的梦想,成功当上了一名光荣的网管。

众所周知,进网吧是要刷身份证的,现在老板让他写一个程序,判断进来的人是否够18周岁(当天恰好是18岁生日也可),并且根据身份证最后一位来校验身份证真伪。

身份证号码共有18位,从左至右编号,第7至第14位为生日,格式为YYYYMMDD,代表年月日。最有一位为校验位,计算规则如下:

1. 将前面的身份证号码17位数分别乘以不同的系数。从第1位到第17位的系数分别为:7, 9, 10, 5, 8, 4, 2, 1, 6, 3, 7, 9, 10, 5, 8, 4, 2。

2. 将这17位数字和系数相乘的结果相加。

3. 用得到的结果除以11,余数为0~10时对应的最后一位为:1,0,X,9,8,7,6,5,4,3,2。

请判断给定的身份证号,如果号码合法且持有人年满18输出“Accepted”,否则输出“Sorry”(均不含引号)。

 
Input
输入包含多组测试数据。

每组输入数据第一行是一个正整数n(n<=1000);

第二行3个“-”号隔开的正整数YYYY-MM-DD,代表今天的日期;

接下来n行每行一组身份证编码,每组编码18位。

 
Output
每组数据输出n行,每行为“Accepted”或“Sorry”(不含引号)。
 
Sample Input
3
2033-02-18
281289202506052608
696815200904169385
980189199511146901
 
Sample Output
Sorry
Accepted
Sorry

Hint

提示:第一个人不满18岁,第三个人身份证号不合法。

 
【分析】:内部置0写到外部,后果就是调bug调到死。
【代码】:

#include <bits/stdc++.h>

using namespace std;
typedef long long ll;
const int N = ; int a[]={,,,,,,,,,,,,,,,,};
char b[] = { '', '', 'X', '', '', '', '', '', '', '', '' };
char s[]; int main()
{
int n,j;
int f1,f2;
int y,m,d,sum,age; while(cin>>n)
{
scanf("%d-%d-%d",&y,&m,&d);
for(int i=;i<n;i++)
{
int yy=,mm=,dd=;//注意内部清零!!!而非外部!!!
char p[] = {""};
char p2[] = {""};
char p3[] = {""};
f1=f2==;
sum=;
scanf("%s",s);
for(j=;j<;j++)//最后位检验
{
sum+=((s[j]-'')*a[j]);
}
sum=sum%;// if(s[]==b[sum]) f1=;
//printf("sum=%d s[17]=%d b[sum]=%d\n",sum,s[17],b[sum]);// strncpy(p, s+, );
for(int i=;p[i];i++)
{
yy=*yy+(p[i]-'');
}
//printf("%d\n",yy);//
strncpy(p2, s+, );
for(int i=;p2[i];i++)
{
mm=*mm+(p2[i]-'');
}
//printf("%d\n",mm);//
strncpy(p3, s+, );
for(int i=;p3[i];i++)
{
dd=*dd+(p3[i]-'');
}
//printf("%d\n",dd);// age=y-yy;//岁数合法判断
//printf("%d\n",age);//2033-2025=8
if(age>)
{
if(age<)
{
f2=;
}
else if(age==)
{
if(m<mm) f2=;
else if(m==mm)
{
if(d<dd) f2=;
else f2=;
}
else f2=;
}
else
{
f2=;
}
}
else
{
f2=;
} //printf("%d %d %d\n",f1,f2,sum);// if(f1== && f2==) puts("Accepted");
else puts("Sorry");
}
}
return ;
}

模拟

HDU 17新生赛 身份证验证【模拟】的更多相关文章

  1. HDU 17新生赛 正品的概率【数论-概率论】

    正品的概率 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total Submi ...

  2. SCNU ACM 2016新生赛初赛 解题报告

    新生初赛题目.解题思路.参考代码一览 1001. 无聊的日常 Problem Description 两位小朋友小A和小B无聊时玩了个游戏,在限定时间内说出一排数字,那边说出的数大就赢,你的工作是帮他 ...

  3. 身份证验证JS代码

    身份证验证JS程序function checkidcardfun(code) { var city = {11: "北京", 12: "天津", 13: &qu ...

  4. java身份证验证

    import java.text.ParseException; import java.text.SimpleDateFormat; import java.util.Calendar; impor ...

  5. jQuery身份证验证插件

    jQuery身份证验证插件 /*! * jQuery isIDCard Plugin v1.0.0 * http://www.cnblogs.com/cssfirefly/p/5629561.html ...

  6. Jsp注册页面身份证验证

    <!--身份证验证 --><script type="text/javascript">function isCardNo(Idcardnumber) { ...

  7. C#实现中国身份证验证问题

    C#中国身份证验证,包括省份验证和校验码验证,符合GB11643-1999标准...   今天写的 C#中国身份证验证,包括省份验证和校验码验证,符合GB11643-1999标准... 理论部分: 1 ...

  8. 52-2018 蓝桥杯省赛 B 组模拟赛(一)java

    最近蒜头君喜欢上了U型数字,所谓U型数字,就是这个数字的每一位先严格单调递减,后严格单调递增.比如 212212 就是一个U型数字,但是 333333, 9898, 567567, 313133131 ...

  9. js邮箱验证,身份证验证,正则表达式

    邮箱验证: html部分: 邮箱验证:<input type="text" id="mail" value="" / onkeyup= ...

随机推荐

  1. 初学JS——实现基于计时器的小游戏。

    这几天一直在看网易云课堂上免费的JS课程,正好今天看到讲了计时器setInterval,第一感觉就是像C#里的TIMER.然后课程里举得例子正好通过计时器改变新生成窗口的位置, 然后就突然有了灵感!可 ...

  2. 更新域名解析以后,IP在cmd中ping不正确,清理DNS缓存

    1清除ARP缓存,cmd下使用命令arp -d*代替执行. 2清除NETBT,cmd下使用命令nbtstat -R代替执行. 再清除DNS缓存,cmd下使用命令ipconfig /flushdns代替 ...

  3. Pascal小游戏 打飞机

    一个经典的打飞机游戏(1)Pascal代码 十分经典,有一种街机的感觉 奇葩青年的又一控制台神作. uses crt; type list=record         ty,ax:integer;  ...

  4. mongodb 部署

    安装mongodb-3.4 1)将安装包上传至服务器 2)对压缩文件进行解压 tar -zxvf mongodb-linux-x86_64-suse12-v3.4-latest.tar.gz 3)把解 ...

  5. URAL 1934 spfa算法

    D - Black Spot Time Limit:1000MS     Memory Limit:65536KB     64bit IO Format:%I64d & %I64u Subm ...

  6. CodeForces Round #515 Div.3 A. Vova and Train

    http://codeforces.com/contest/1066/problem/A Vova plans to go to the conference by train. Initially, ...

  7. PHP命名空间与use

    当在一个大型项目很多程序员书写模板时,最怕出现的问题就是命名,如果一个PHP脚本出现了同名的类或者方法,就会报错(fatal error),使用命名空间可以 解决这个问题 知识点: 命名空间names ...

  8. PHP面向对象 封装与继承

    知识点: PHP封装三个关键词: 一.public 公有的,被public修饰的属性和方法,对象可以任意访问和调用 二.private 私有的,被private修饰的属性和方法,只能在类内部的方法可以 ...

  9. Password [分块]

    题面 $n,m,x \leq 10^5$ 思路 首先$n=2$做法很多,不讲了 $n=3$的时候,分块维护两个东西:每一个数出现次数的前缀和,和出现次数的出现次数的前缀和(说的有点绕,但是应该挺好理解 ...

  10. 洛谷 P3349 [ZJOI2016]小星星 解题报告

    P3349 [ZJOI2016]小星星 题目描述 小\(Y\)是一个心灵手巧的女孩子,她喜欢手工制作一些小饰品.她有\(n\)颗小星星,用\(m\)条彩色的细线串了起来,每条细线连着两颗小星星. 有一 ...