指针原来是套娃的


私信TA

用户名:uq_92467646842

访问量:52545

签 名:

个人博客:blog.imtwa.top

等  级
排  名 11
经  验 26533
参赛次数 49
文章发表 128
年  龄 0
在职情况 学生
学  校
专  业 物联网工程

  自我简介:

解题思路:
先解释一下题目,要求检查识别码是否正确,识别码是最后一位的数字

0-670-82162-4,这里最后一位的4就是识别码。

4=(0×1+6×2+……+2×9)%11;

注意如果最后得10,识别码为大写的X。

对于char型字符数字转为int型,可以用('9'-'0')字符码之间相减得到int型整数

详见代码注释:

#include <iostream>
#include <algorithm>

using namespace std;


int main() {
	string s;
	while(cin>>s){
		int z=0;
		char x=s[s.size()-1];//x获取到最后一位的识别码,便于比较
		 
		for(int i=0,j=1;i<s.size()-1;i++){//注意s.size()-1,截止到识别码之前停止 
			if(s[i]>='0'&&s[i]<='9'){//如果是数字 
				z+=(s[i]-'0')*j;//转为int型 
				z%=11;//取余 
				j++;
			}
		} 
		//判断,如果z=10则x应为大写的X,或者数字对应 
		if((z==10&&x=='X')||(char)(z+'0')==x)cout<<"Right"<<endl;
		else {
			//否则将x转换为正确的识别码 
			x=(z==10?'X':(char)(z+'0'));
			s[s.size()-1]=x;//将原识别码替换 
			cout<<s<<endl;//直接打印 
		}
	}

	return 0;
}

注意,这里是在相加的过程中就取余

根据同余

(a+b+c) mod n ==(a%n+b%n+c%n) mod n

效果和相加完最后再取余是一样的。

以上。

 

0.0分

154 人评分

  评论区

  • «
  • »