int checkID(char *ID) {int sum; int g[]={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=1;i<19;i++){ sum+=(ID[i]-'0')*g[i];} int h=sum%11; return ID[18]==check[h]; }画出流程图
时间: 2024-01-16 14:02:25 浏览: 23
抱歉,我无法在这里直接绘制流程图。但我可以向您推荐一些在线工具,您可以使用这些工具来绘制流程图:
- ProcessOn
- Lucidchart
- Draw.io
- Microsoft Visio (需要订阅)
您可以在其中任何一个工具中创建一个新的流程图,并按照以下步骤添加流程:
1. 创建一个开始节点
2. 创建一个输入节点,名称为"ID"
3. 创建一个变量节点,名称为"sum",初始值为0
4. 创建一个数组节点,名称为"g",值为{7,9,10,5,8,4,2,1,6,3,7,9,10,5,8,4,2}
5. 创建一个数组节点,名称为"check",值为{'1','0','X','9','8','7','6','5','4','3','2'}
6. 创建一个循环节点,循环范围为1到18,计数器为"i"
7. 在循环节点中添加以下节点:
- 创建一个计算节点,计算公式为:(ID[i]-'0')*g[i],结果保存到"temp"变量中
- 创建一个加法节点,将"sum"和"temp"相加,结果保存到"sum"中
8. 创建一个计算节点,计算公式为:sum%11,结果保存到"h"变量中
9. 创建一个比较节点,比较ID[18]和check[h]是否相等,结果作为函数的返回值
这些步骤可能因工具而异,但大致流程应该是相似的。希望这可以帮助您绘制流程图。
相关问题
描述下面程序流程图的画法#include <stdio.h> struct ID { char num[18]; }; int checkID(char *ID); int main() { struct ID id; printf("请输入18位身份证号码:"); scanf("%s", id.num); if (checkID(id.num)) { printf("校验位正确\n"); } else { printf("校验位错误\n"); } return 0; } int checkID(char *ID) { int i, sum = 0; int weight[17] = {7, 9, 10, 5, 8, 4, 2, 1, 6, 3, 7, 9, 10, 5, 8, 4, 2}; char check[11] = {'1', '0', 'X', '9', '8', '7', '6', '5', '4', '3', '2'}; for (i = 0; i < 17; i++) { sum += (ID[i] - '0') * weight[i]; } if (check[sum % 11] == ID[17]) { return 1; } else { return 0; } }
以下是描述该程序流程图的画法:
1. 开始节点
2. 输入节点:提示用户输入18位身份证号码
3. 处理节点:将用户输入的身份证号码存储到结构体变量id的num成员中
4. 调用checkID函数进行校验
5. 判断节点:如果校验位正确,输出“校验位正确”,否则输出“校验位错误”
6. 结束节点
其中,checkID函数包含以下节点:
1. 开始节点
2. 处理节点:定义变量i和sum,分别表示循环计数器和身份证号码前17位的加权和,定义数组weight和check,分别表示身份证号码前17位的权重和校验码
3. 循环节点:循环17次,计算身份证号码前17位的加权和
4. 判断节点:根据加权和计算校验码,判断校验码是否与身份证号码的第18位相等
5. 判断节点:如果校验码相等,返回1,否则返回0
6. 结束节点
) int checkID(char *ID); (7分) 判别身份证校验位是否正确的函数。其中参数 ID 代表一个 18 位身份证号,如果校验位正确,函数返回 1,否则返回 0。
以下是一个简单的实现,用于判别身份证校验位是否正确:
```
int checkID(char *ID) {
int weight[] = {7, 9, 10, 5, 8, 4, 2, 1, 6, 3, 7, 9, 10, 5, 8, 4, 2};
char checkCode[] = {'1', '0', 'X', '9', '8', '7', '6', '5', '4', '3', '2'};
int sum = 0;
for (int i = 0; i < 17; i++) {
sum += (ID[i] - '0') * weight[i];
}
int index = sum % 11;
return ID[17] == checkCode[index];
}
```
这个函数的实现基于以下的校验规则:
1. 前 17 位数字分别乘以对应的权重,然后求和。
2. 将上面的和除以 11 取余数,得到一个数字。
3. 根据余数查表得到一个校验码。
4. 如果身份证号的最后一位是上面得到的校验码,那么校验成功。
注意,这个实现并没有对输入的身份证号进行任何格式检查,比如说长度是否为 18 位,前 17 位是否都是数字等等。如果需要更严格的检查,可以在函数中加入相应的代码。
相关推荐
![rar](https://img-home.csdnimg.cn/images/20210720083606.png)
![pdf](https://img-home.csdnimg.cn/images/20210720083512.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![pdf](https://img-home.csdnimg.cn/images/20210720083512.png)