问题 K: 车牌校验
时间限制: 1 Sec 内存限制: 128 MB
题目描述
交警检查交通,他们发现有不少人通过更改车牌来逃避检查,于是,请来桂城的电脑专家——晨晨,来为他们解决这个难题。晨晨想了一个办法,一眼就可以看出车牌有没有更改。
已知车牌由英文字母和数字组成,一共有六个字符,晨晨给每辆车编了一个2位数字的校验码,编码的方法是:如果是字母把它们的ASCII码加起来变成整数N1,如果是数字按先后顺序组成一个整数N2,最后用N1+N2的和对100求余后的余数即为此车的校验码,此编码要粘在汽车的前档风玻璃上,这样就可以看车牌与编码的是否对应来断定车主有没有更改车牌了。
输入
一行,只含大写字母或数字的6个字符,表示车牌号码。
输出
一个2位数字的整数,表示车牌的校验码。
样例输入 Copy
YMV312
样例输出 Copy
64
提示
(89+77+86+312) mod 100=64
#include <iostream>
#include <cstdio>
#include <string>
#include <math.h>
#include <string.h>
#include <algorithm>
using namespace std;
#define maxSize 100
int main()
{
string str;
cin>>str;
int num1=0,num2=0;
for(int i=0; str[i]!='\0'; i++)
{
if(str[i]<='9'&&str[i]>='0')
{
num1=num1*10+str[i]-'0';
}
else
{
num2=num2+char(str[i]);
}
}
int num=(num1+num2)%100;
printf("%02d\n",num);
return 0;
}
注意最后一句话,输出两位整数。
257

被折叠的 条评论
为什么被折叠?



