杭电2629 Identity Card

原创 2015年11月20日 18:46:43

Identity Card

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


Problem Description
Do you own an ID card?You must have a identity card number in your family's Household Register. From the ID card you can get specific personal information of everyone. The number has 18 bits,the first 17 bits contain special specially meanings:the first 6 bits represent the region you come from,then comes the next 8 bits which stand for your birthday.What do other 4 bits represent?You can Baidu or Google it.
Here is the codes which represent the region you are in.
 
However,in your card,maybe only 33 appears,0000 is replaced by other numbers.
Here is Samuel's ID number 331004198910120036 can you tell where he is from?The first 2 numbers tell that he is from Zhengjiang Province,number 19891012 is his birthday date (yy/mm/dd).
 

Input
Input will contain 2 parts:
A number n in the first line,n here means there is n test cases. For each of the test cases,there is a string of the ID card number.
 

Output
Based on the table output where he is from and when is his birthday. The format you can refer to the Sample Output.
 

Sample Input
1 330000198910120036
 

Sample Output
He/She is from Zhejiang,and his/her birthday is on 10,12,1989 based on the table.
 

Author
Samuel
 

Source
 

Recommend
zty   |   We have carefully selected several similar problems for you:  2626 2628 2630 2634 2632 
 


水题吧,这样的字符串问题我实在是不想做了。

代码:

#include<stdio.h>
#include<string.h>
#include<algorithm>
using namespace std;
char s[][100]={"Zhejiang","Beijing","Taiwan","Hong Kong","Macao","Tibet","Liaoning","Shanghai"};
char year[10],month[10],day[10];
char c[110000];
int a[]={33,11,71,81,82,54,21,31};
int i,j,k,l,m,n;
int main()
{
	scanf("%d",&n);
	while(n--)
	{
		scanf("%s",c);
		m=(c[0]-'0')*10+c[1]-'0';
		for(i=0;i<8;i++)
		if(m==a[i])
		break;
		l=i;
		month[0]=c[10];
		month[1]=c[11];
		month[2]='\0';
		day[0]=c[12];
		day[1]=c[13];
		day[2]='\0';
		j=6;
		for(i=0;i<4;i++)
		year[i]=c[j++];
		year[i]='\0';
		printf("He/She is from %s,and his/her birthday is on %s,%s,%s based on the table.\n",s[l],month,day,year);
	}
}



版权声明:本文为博主原创文章,未经博主允许不得转载。

杭电ACM——Java版

记录杭电ACM的部分答案,纯手写,如有雷同,算你抄我的。o(∩_∩)o
  • young_kim1
  • young_kim1
  • 2015年04月17日 10:29
  • 1901

杭州电子科技大学(HDU)ACM 刷题---------字符串处理之1062

字符串转序
  • zys_1997
  • zys_1997
  • 2016年04月09日 12:32
  • 1380

杭电acm题目分类 非常详细

按此做成就大神之路:   1002 简单的大数 1003 DP经典问题,最大连续子段和 1004 简单题 1005 找规律(循环点) 1006 感觉有点BT的题,我到现在还没过 1007...
  • lsgqjh
  • lsgqjh
  • 2015年03月13日 17:49
  • 8124

杭电ACM 2629: Identity Card

原创作品 转载请注明出处http://blog.csdn.net/always2015/article/details/45391791整个题目难点就是获取字符串的各位的值,很容易想到利用下标就可以做...
  • Always2015
  • Always2015
  • 2015年04月30日 10:40
  • 727

hdu2629 Identity Card (2016xynu暑期集训检测 -----F题)

Identity Card Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) ...
  • su20145104009
  • su20145104009
  • 2016年08月31日 13:43
  • 1315

HDU2629 Identity Card【MAP+水题】

Identity Card Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) To...
  • tigerisland45
  • tigerisland45
  • 2017年07月02日 00:06
  • 271

元旦假期归来~[水题][第一阶段-英文题试水][HDOJ-2629]Identity Card

Problem Description Do you own an ID card?You must have a identity card number in your family's H...
  • rainxbow
  • rainxbow
  • 2015年01月05日 04:54
  • 357

杭电 Identity Card

Identity Card Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others...
  • mxdlove00
  • mxdlove00
  • 2012年06月09日 21:18
  • 1074

杭电2629

Identity Card Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) ...
  • jingshui1234
  • jingshui1234
  • 2013年01月28日 18:18
  • 369

杭电 hdu 1528 Card Game Cheater (二分图,最大匹配)

/* THE PROGRAM IS MADE BY PYY */ /*-----------------------------------------------------------------...
  • panyanyany
  • panyanyany
  • 2011年08月27日 16:58
  • 997
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:杭电2629 Identity Card
举报原因:
原因补充:

(最多只允许输入30个字)