C++知识点总结(23):高级模拟算法真题 ★★★☆☆《身份证号码》

身份证号码

1. 审题

题目描述

中华人民共和国居民身份证,是用于证明居住在中华人民共和国境内的公民身份证明文件。上面有公民姓名、性别、民族、出生、住址及 18 18 18 位公民身份号码等信息,其中公民身份号码是编定的唯一的、终身不变的身份代码,该号码是特征组合码,由十七位数字本体码和一位数字校验码组成。其排列顺序从左至右依次为:前六位数字代表地址信息,八位数字代表出生日期,三位数字是顺序码、一位数字为校验码。
校验码的计算方法如下:
1、将前面的身份证号码 17 17 17 位数分别乘以不同的系数。从第一位到第十七位的系数分别为 7 7 7 9 9 9 1 1 1 0 0 0 5 5 5 8 8 8 4 4 4 2 2 2 1 1 1 6 6 6 3 3 3 7 7 7 9 9 9 1 1 1 0 0 0 5 5 5 8 8 8 4 4 4 2 2 2
2、将这 17 17 17 位数字和系数相乘的结果相加;
3、用加出来和除以 11 11 11,看余数是多少;
4、余数只可能有 0 − 10 0-10 010 11 11 11个数字。其分别对应的最后一位身份证的号码为 1 1 1 0 0 0 X X X 9 9 9 8 8 8 7 7 7 6 6 6 5 5 5 4 4 4 3 3 3 2 2 2(大写的 X X X);
例如:某男性的身份证号码是 34052419800101001 X 34052419800101001X 34052419800101001X。我们要看看这个身份证是不是合法的身份证。
首先:我们计算 3 × 7 + 4 × 9 + 0 × 10 + 5 × 5 + . . + 1 × 2 3\times7+4\times9+0\times10+5\times5+..+1\times2 3×7+4×9+0×10+5×5+..+1×2,前 17 17 17 位的乘积和是 189 189 189
然后:用 189 189 189 除以 11 11 11 得出的结果是商 17 17 17 2 2 2
最后:通过对应规则就可以知道余数 2 2 2 对应的数字是 X X X。所以,这是一个合格的身份证号码。

输入描述

一个字符序列,表示一个人的身份证号码。

输出描述

一行,假如输入的身份证号码是正确,那么输出 Right,否则,输出正确的身份证号码。

2. 思路

这是一道比较简单的题目,主要考察这几个知识点:
string 字符串的操作 模拟算法
我们可以利用一个函数 valid() 来返回一个正确的身份证号码,或者是 "Right"。思路还是很简单的,按照题目写就可以了。

3. 参考答案

#include <iostream>
#include <string>
using namespace std;

string s; // 身份证号码

string valid(string &id)
{
    string correct;
    int sum = 0;
    int factors[] = {7, 9, 10, 5, 8, 4, 2, 1, 6, 3, 7, 9, 10, 5, 8, 4, 2};
    char check[] = {'1', '0', 'X', '9', '8', '7', '6', '5', '4', '3', '2'};
    for (int i = 0; i < 17; i++)
    {
        sum += (id[i] - '0') * factors[i];
    }
    sum %= 11;
    correct = id.substr(0, 17) + check[sum];
    
    if (id == correct)
    {
        return "Right";
    }
    else
    {
        return correct;
    }
}

int main()
{
    // 输入数据
    cin >> s;
    
    // 核对校验码并输出
    cout << valid(s);
    return 0;
}
  • 17
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,这是一个简单的C++实验,让我们一步步来实现。 题目描述: 输入一个18位的身份证号码,输出其中的出生日期,格式为YYYY-MM-DD。 身份证号码前6位为地址码,7到14位为出生日期码,15到17位为顺序码,最后一位为校验码。 注意:身份证号码中的出生日期码前8位表示的是出生日期,其格式为YYYYMMDD。 解题思路: 我们可以通过截取身份证号码中的出生日期码前8位,然后将其按照YYYY-MM-DD的格式进行输出。具体步骤如下: 1. 首先,使用cin输入身份证号码,存储在一个string类型的变量中。 2. 然后,截取身份证号码中的出生日期码前8位,存储在一个string类型的变量中。 3. 接着,将这个string类型的变量转换为整型,存储在一个int类型的变量中。 4. 然后,按照YYYY-MM-DD的格式进行输出。 下面是完整的C++代码实现: ```c++ #include<iostream> #include<string> using namespace std; int main() { string id_number; cout << "Please enter your 18-digit ID number: "; cin >> id_number; string birthday_str = id_number.substr(6, 8); int birthday_int = stoi(birthday_str); int year = birthday_int / 10000; int month = (birthday_int % 10000) / 100; int day = birthday_int % 100; cout << "Your birthday is: " << year << "-" << month << "-" << day << endl; return 0; } ``` 在这个程序中,我们首先使用`cin`输入身份证号码,并将其存储在一个名为`id_number`的字符串变量中。 然后,我们使用`substr`函数截取出生日期码前8位,存储在一个名为`birthday_str`的字符串变量中。 接着,我们使用`stoi`函数将`birthday_str`转换为一个整型变量`birthday_int`。 然后,我们使用算术运算将`birthday_int`按照年、月、日的顺序进行拆分,分别存储在`year`、`month`和`day`这三个整型变量中。 最后,我们按照YYYY-MM-DD的格式,使用`cout`输出出生日期。 希望这个实验能帮到你!

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值