【洛谷】P1055 ISBN号码 【题解】
这题虽然在洛谷中是普及-难度,但是我觉得还是挺简单的;
因为题目中已经说过数字有十位,识别码有一位,所以只要判断前面九个数字乘多少的和 mod 11就可以了!
注意:余数为10时,是X!并且要用char数组!
代码:
#include<iostream>
using namespace std;
int main(){
char isbn[1001]={};
cin>>isbn;
int num=0;
for(int i=0,j=0;j<9;i++,j++){
if(isbn[i]=='-')j--;
else num+=(isbn[i]-48)*(j+1);
}if(isbn[12]=='X')isbn[12]=58;
if(num%11==isbn[12]-48)cout<<"Right";
else{
for(int i=0;i<12;i++)cout<<isbn[i];
if(num%11==10)cout<<'X';
else cout<<num%11;
}return 0;
}
大家觉得这题是不是很简单?