样例输入
0-670-82162-4
样例输出
Right
样例输入
0-670-82162-0
样例输出
0-670-82162-4
notice:总结一下出现50分80分的原因:
1.忽略题目要求:如果取余==10 则输出最后一个应为X
2.忘记了输入是时候 如果最后是X并且取余==10 那么输出应为True
以下是两个主要方法
方法一:笨办法
思路:根据条件输入,字符'-'直接丢掉,剩下的所有数字放进数组a 然后遍历计算ans,最后条件判断
code:
#include <bits/stdc++.h>
using namespace std;
int a[13];
int main()
{
int ans = 0, factor = 1;
char c;
for (int i = 0; i < 13; i++) //数据输入
{
if (i != 1 && i != 5 && i != 11)
{
if (i == 12)
{
cin>>c;
a[12]=c-'0';
continue;
}
cin >> c;
a[i]=c-'0';
ans += (a[i] * factor);
factor++;
}
else
cin>>c;
}
ans %= 11;
if (ans == a[12]||(ans==10 && c=='X'))
cout << "Right";
else
{
a[12]=ans;
for (int i = 0; i < 13; i++) //数据输出
{
if(i==12 && ans==10)
{
cout<<"X";
break;
}
if (i != 1 && i != 5 && i != 11)
{
cout << a[i];
}
else
cout << "-";
}
}
return 0;
}
方法二:利用string(较方便)进行处理
思路:先整体输入此string 然后通过isdigit()处理数字 最后条件判断输出;
code:
#include<bits/stdc++.h>
using namespace std;
string s1;
int A[10],sum = 0,factor = 1;
int main()
{
cin>>s1;
int p;
for(int i = 0;i < 11;i++)
{
if(isdigit(s1[i]) != 0)
{
sum += (s1[i] - '0')*factor;
factor++;
}
}
sum %= 11;
if((s1[12] - '0') == sum||(sum == 10 && s1[12] == 'X'))
cout<<"Right"<<endl;
else
{
for(int i = 0; i < s1.size() - 1;i++)
{
cout<<s1[i];
}
if(sum == 10)
cout<<"X"<<endl;
else
cout<<sum<<endl;
}
return 0;
}