题意:一种数,如0201103311是ISBN数,取值方法为10*0 + 9*2 + 8*0 + 7*1 + 6*1 + 5*0 + 4*3 + 3*3 + 2*1 + 1*1 = 55. 如果这个值可以整除11,则成立,现在取一列中一个为?,算出如果这个是ISBN数,?代表什么数。
思路:直接计算现有值的总和,然后运算出缺少位数的值。
注意点:
1)如果取不到任何值使得这个数位ISBN数,就输出-1.
2)如果是末尾数为10,则输出'X';其他位数也可能为10,则输出-1.
没写while(cin>>a)贡献了一次WA,然后为10的时候直接输出了10,又贡献了一次WA。不过还是水题……
#include<iostream>
using namespace std;
int main()
{
char a[12];
int i,j,k,sum;
while(cin>>a)
{
sum=0;
for(i=0,j=10;i<10;i++,j--)
if(a[i]!='?')
{
if(a[i]!='X') sum+=(a[i]-'0')*j;
else sum+=10;
}
else k=j;
for(i=0;i<=10;i++)
if((sum+i*k)%11==0&&i<=9)
{
cout<<i<<endl;
break;
}
else if((sum+i*k)%11==0&&i==10&&a[9]=='?')
{
cout<<'X'<<endl;
break;
}
if(i==11) cout<<"-1"<<endl;
}
return 0 ;
}