我觉得今天是我的幸运日啊,运行了两个题目都全过了。nice,兄弟;
今天记得题目如下:
这个号码,一共有13个字符,所以可以使用string类直接弄成一个大小为13的数组,不过这样在输入的时候会需要for循环,我尽量避免了for循环的出现,为了压缩运算复杂度嘛;然后就是对里面每一个数据的判断,是 ‘0’ 到 ‘9’ 的字符就进行累乘的操作,然后得到一个记录大小的sum的值。然后就是使用sum5%11的结果来和最后一个字符与‘0’的差值比较,看看是否对等,是的话就是输出right,不是的话,就需要改掉最后一个字符。
代码如下:
#include<iostream>
#include<string>
using namespace std;
string s;
char c[11] = { '0','1','2','3','4','5','6','7','8','9','X' };
int sum = 0, n = 1;
int main() {
cin >> s;
for (int i = 0; i < s.size() - 1; i++) {
if (s[i] >= '0' && s[i] <= '9') {
sum += (s[i] - '0') * n;
n++;
}
}
if (sum % 11 == (s[s.size() - 1] - '0'))cout << "right" << endl;
else if (sum % 11 == 10 && s[s.size() - 1] == 'X')cout << "right" << endl;
else {
s[s.size() - 1] = c[sum % 11];
cout << s;
}
return 0;
}
在开头,需要定义一个char的数组,来将sum%11的结果表示一下。