栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > C/C++/C#

pta乙级1031查验身份证(AC)

C/C++/C# 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

pta乙级1031查验身份证(AC)

思路:

1.把18位的身份证分成18个字符

2.先判断前17位是否全为数字,若不是,直接输出这些字符;若是,直接计算出他们加权的结果,得出Z,与M比较。

#include
using namespace std;
int main()
{
	char a[20];
	int n=0,z=0,num=0,judge=0,flag=0;
	int b[17]={7,9,10,5,8,4,2,1,6,3,7,9,10,5,8,4,2};
	cin>>n;
	for(int i=1;i<=n;i++)
	{
		int pd=0;
		for(int j=0;j<18;j++) cin>>a[j];
		for(int k=0;k<=16;k++)
		{
			if(a[k]>'9'||a[k]<'0')
			{
				pd++;
				if(flag==1) cout< 

错误:num第一次计算完忘记清0了,导致答案一直不对。

感觉最后Z和M的对应可以改进一下,用十一进制来做,有机会发一下。

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/311830.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号