zoukankan      html  css  js  c++  java
  • HDU2629 Identity Card【MAP+水题】

    Identity Card

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

    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

    问题链接HDU2629 Identity Card

    题意简述:参见上文。

    问题分析:解释身份证上省份和生日信息。

    程序说明:(略)

    题记:(略)


    AC的C++语言程序如下:

    /* HDU2629 Identity Card */
    
    #include <iostream>
    #include <map>
    #include <string>
    #include <stdio.h>
    
    using namespace std;
    
    map<int, string> m;
    
    int main()
    {
        int n;
        string id;
    
        m[33] = "Zhejiang";
        m[82] = "Macao";
        m[11] = "Beijing";
        m[54] = "Tibet";
        m[71] = "Taiwan";
        m[21] = "Liaoning";
        m[81] = "Hong Kong";
        m[31] = "Shanghai";
    
        cin >> n;
        while(n--) {
            cin >> id;
    
            int region;
            region = (id[0] - '0') * 10 + (id[1] - '0');
            printf("He/She is from %s,and his/her birthday is on ", m[region].c_str());
            printf("%c%c,%c%c,%c%c%c%c", id[10], id[11], id[12], id[13], id[6], id[7], id[8], id[9]);
            printf(" based on the table.
    ");
        }
    
        return 0;
    }



  • 相关阅读:
    实验5 Spark SQL 编程初级实践
    豆瓣基础架构
    淘宝数据魔方技术架构解析
    质量属性的六个常见属性场景--淘宝网
    Win10家庭版WindowsUpdate属性为灰色
    豆瓣的基础架构
    京东618实践:一元抢宝系统的数据库架构优化
    FunData — 电竞大数据系统架构演进
    Ubuntu14.0使用gparted调整分区大小
    二阶段开发冲刺一
  • 原文地址:https://www.cnblogs.com/tigerisland/p/7563630.html
Copyright © 2011-2022 走看看