1031. 查验身份证(15)

一个合法的身份证号码由17位地区、日期编号和顺序编号加1位校验码组成。校验码的计算规则如下:

首先对前17位数字加权求和,权重分配为:{7,9,10,5,8,4,2,1,6,3,7,9,10,5,8,4,2};然后将计算的和对11取模得到值Z;最后按照以下关系对应Z值与校验码M的值:

Z:0 1 2 3 4 5 6 7 8 9 10
M:1 0 X 9 8 7 6 5 4 3 2

现在给定一些身份证号码,请你验证校验码的有效性,并输出有问题的号码。

输入格式:

输入第一行给出正整数N(<= 100)是输入的身份证号码的个数。随后N行,每行给出1个18位身份证号码。

输出格式:

按照输入的顺序每行输出1个有问题的身份证号码。这里并不检验前17位是否合理,只检查前17位是否全为数字且最后1位校验码计算准确。如果所有号码都正常,则输出“All passed”。

输入样例1:

4
320124198808240056
12010X198901011234
110108196711301866
37070419881216001X

输出样例1:

12010X198901011234
110108196711301866
37070419881216001X

输入样例2:

2
320124198808240056
110108196711301862

输出样例2:

All passed
#include<cstdio>
#include<cstring>
int w[20]={  // int类型数组赋初值不要加‘’ 7,9,10,5,8,4,2,1,6,3,7,9,10,5,8,4,2
};
char M[15] = {  //char类型加‘’ '1','0','X','9','8','7','6','5','4','3','2'
};
int main(){char str[20];int k;bool flag = true;scanf("%d",&k);for(int j = 0; j < k; j++){scanf("%s",str);int sum = 0,len = strlen(str),i;for(i = 0; i < 17; i++){  // 要用i<17,不能用i<len if(! (str[i] >= '0' && str[i] <= '9')) break;  //如果前17个不是0-9的数字,不合法 sum = sum + w[i]*(str[i] - '0');}if(i < 17){  //要判断是否够18位,不是,返回错误 flag = false;printf("%s\n",str);}else{if(M[sum % 11] != str[17]) {   //判断权重是否相同 printf("%s\n",str);flag = false;}}}if(flag == true) printf("All passed");return 0;
}

 

#include<cstdio>
#include<cstring>int w[20]={  // int类型数组赋初值不要加‘’ 7,9,10,5,8,4,2,1,6,3,7,9,10,5,8,4,2
};
char M[15] = {  //char类型加‘’ '1','0','X','9','8','7','6','5','4','3','2'
};bool isvalid(char str[]){int i,sum = 0;for(i = 0; i < 17; i++){if(!(str[i] >= '0' && str[i] <= '9')) return false;sum += (str[i] - '0') * w[i];}if(i < 17) return false;else if(M[sum%11] == str[17]) return true;else return false;
}int main(){int n;char id[110];scanf("%d",&n);bool flag = true;for(int i = 0; i < n; i++){scanf("%s",id);if(!isvalid(id)){printf("%s\n",id);flag = false;}}if(flag) printf("All passed");return 0;
}

 

转载于:https://www.cnblogs.com/wanghao-boke/p/8543450.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/385436.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

虚拟地址空间

对于每一个进程都会对应一个虚拟地址空间&#xff0c;对于32位的操作系统&#xff08;其指令的位数最大为32位&#xff0c;因此地址码最多32位&#xff09;&#xff0c;虚拟地址空间的大小为B即0~4GB的虚拟地址空间&#xff0c;其中内核空间为1GB&#xff0c;如下所示&#xff…

Leecode 69. x 的平方根

实现 int sqrt(int x) 函数。 计算并返回 x 的平方根&#xff0c;其中 x 是非负整数。 由于返回类型是整数&#xff0c;结果只保留整数的部分&#xff0c;小数部分将被舍去。 示例 1: 输入: 4 输出: 2 示例 2: 输入: 8 输出: 2 说明: 8 的平方根是 2.82842..., 由于返回类…

1002. 写出这个数 (20)

读入一个自然数n&#xff0c;计算其各位数字之和&#xff0c;用汉语拼音写出和的每一位数字。 输入格式&#xff1a;每个测试输入包含1个测试用例&#xff0c;即给出自然数n的值。这里保证n小于10100。 输出格式&#xff1a;在一行内输出n的各位数字之和的每一位&#xff0c;拼…

C/C++中NULL指针

先谈一下C/C的强制类型转换Type cast。与强制类型转换相对应的是自动类型转换。或者强制类型转换叫显示类型转换&#xff0c;自动类型转换叫隐式类型转换。自动类型转换会在赋值运算、混合运算、参数传递、返回函数返回值、格式化输出时且当类型出现不一致时发生&#xff0c;转…

1009. 说反话 (20)

给定一句英语&#xff0c;要求你编写程序&#xff0c;将句中所有单词的顺序颠倒输出。 输入格式&#xff1a;测试输入包含一个测试用例&#xff0c;在一行内给出总长度不超过80的字符串。字符串由若干单词和若干空格组成&#xff0c;其中单词是由英文字母&#xff08;大小写有区…

动态库(共享库)的制作和使用

Linux下的动态库为lib*.so格式的二进制文件&#xff08;目标文件&#xff09;&#xff0c;对应于Windows下的.dll格式的文件。 &#xff08;1&#xff09;命名规则 lib库名.so &#xff08;2&#xff09;动态库的制作 1&#xff09;生成与位置无关的代码&#xff08;.o&…

孤儿进程、僵尸进进程

一、儿进程与僵尸进程 1、基本概念 我们知道在unix/linux中&#xff0c;正常情况下&#xff0c;子进程是通过父进程创建的&#xff0c;子进程在创建新的进程。子进程的结束和父进程的运行是一个异步过程,即父进程永远无法预测子进程 到底什么时候结束。 当一个 进程完成它的工…

管道 -pipe

gcc编译器将源代码编译成可执行程序的过程中&#xff0c;需要经过许多中间步骤&#xff08;预处理、编译、汇编、链接&#xff09;&#xff0c;这些过程实际上是由不同的程序来负责完成的&#xff08;/usr/bin/gcc、cpp、ccl、as和ld等&#xff09;。在这个过程的每一个阶段中&…

gdb调试器(一)

在默认情况下&#xff0c;gcc在编译时不会把调试符号插入到最终生成的二进制代码&#xff08;机器代码&#xff09;中&#xff0c;因为这样会急剧增加可执行程序的大小。如果需要在编译时生成调试符号的信息&#xff0c;则可以采用-g或-ggdb参数。 gcc在产生调试信息时&#x…

1048. 数字加密(20)

本题要求实现一种数字加密方法。首先固定一个加密用正整数A&#xff0c;对任一正整数B&#xff0c;将其每1位数字与A的对应位置上的数字进行以下运算&#xff1a;对奇数位&#xff0c;对应位的数字相加后对13取余——这里用J代表10、Q代表11、K代表12&#xff1b;对偶数位&…

网络编程套接字API

uint32_t htonl(uint32_t hostlong); uint16_t htons(uint16_t hostshort); uint32_t ntohl(uint32_t netlong); uint16_t ntohs(uint16_t netshort);int inet_pton(int family, const char *strptr, void *addrptr); 分析&#xff1a; 第一个参数可以是AF_INET或AF_INET6&am…

gdb调试器(二)

Linux下的gdb&#xff08;GNU Debugger&#xff09;是一个用来调试C、C程序的调试器&#xff08;命令行方式的调试器&#xff09;&#xff0c;能够在程序运行期间观察程序的内部结构和内存的使用情况。程序员也可以使用gdb来跟踪程序中的错误&#xff0c;从而减少程序员的工作量…

gdb调试器(三)

File/file 装入想要调试的可执行文件 run(r) 执行当前被调试的程序 kill(k) 终止正在调试的程序 quit(q) 退出gdb shell 使用户不离开gdb就可以执行Linux的shell命令 backtrace(bt) 回溯跟踪&#xff08;当对代码进行调试时&#xff0c;run后…

IO多路复用之poll

1. poll函数原型&#xff1a; int poll(struct pollfd *fds, nfds_t nfds, int timeout);参数&#xff1a; fds&#xff1a;指向一个结构体数组的第0个元素的指针&#xff0c;每个数组元素都是一个struct pollfd结构&#xff0c;用于指定测试某个给定的fd的条件 nfds&#x…

makefile文件的书写规则(make和makefile)

对于makefile&#xff0c;掌握一个规则&#xff0c;两个变量和三个函数。下面介绍一个规则。 makefile的作用&#xff1a;一个项目代码的管理工具。当一个项目的代码文件数&#xff08;如.c文件&#xff09;太多&#xff0c;用gcc编译会太麻烦&#xff0c;如果全部文件一次性编…

100. 相同的树

给定两个二叉树&#xff0c;编写一个函数来检验它们是否相同。 如果两个树在结构上相同&#xff0c;并且节点具有相同的值&#xff0c;则认为它们是相同的。 示例 1: 输入: 1 1 / \ / \ 2 3 2 3 [1,2,3], [1,2,3] 输出: true…

makefile的两个变量(自动变量和普通变量)

(1)普通变量 如&#xff1a; objmain.o add.o sub.o mul.o div.o //将后面的值赋值给obj&#xff0c;obj就是一个普通变量 targetzsx //将zsx赋值给target makefile中已经定义的一些普通变量&#xff08;通常格式都是大写&#xff0c;类似环境变量&#xff0c;它们都是普通…

【C++ Priemr | 15】虚函数表剖析(二)

一、多重继承&#xff08;无虚函数覆盖&#xff09; 下面&#xff0c;再让我们来看看多重继承中的情况&#xff0c;假设有下面这样一个类的继承关系。注意&#xff1a;子类并没有覆盖父类的函数。 测试代码&#xff1a; class Base1 { public: virtual void f() { cout <…

1074. Reversing Linked List (25)

Given a constant K and a singly linked list L, you are supposed to reverse the links of every K elements on L. For example, given L being 1→2→3→4→5→6, if K 3, then you must output 3→2→1→6→5→4; if K 4, you must output 4→3→2→1→5→6. Input Spe…

【Leetcode | 47】 222. 完全二叉树的节点个数

给出一个完全二叉树&#xff0c;求出该树的节点个数。 说明&#xff1a; 完全二叉树的定义如下&#xff1a;在完全二叉树中&#xff0c;除了最底层节点可能没填满外&#xff0c;其余每层节点数都达到最大值&#xff0c;并且最下面一层的节点都集中在该层最左边的若干位置。若最…