这里是第一题的题干:https://www.luogu.org/problemnew/show/P1055
这道题,有点玄幻(不要问我为什么)
直接看代码吧(毕竟说多了都是伤心泪):
#include<iostream>
#include<cstdio>
#include<cstring>
#include<string>
using namespace std;
string a;
int num=1,multiply=0;
int main()
{
freopen("isbn.in","r",stdin);
freopen("isbn.out","w",stdout);
getline(cin,a);//这里很奇怪,在洛谷上面,这样是过不了的(cin>>a才行)。
//但是,在lemon上面这样写是完全没有问题的。。。
int len=a.size();
for(int i=0;i<len-1;++i){
if(a[i]>='0'&&a[i]<='9'){
multiply+=(a[i]-48)*num;
num++;
}
}
int b=multiply%11;//先求出ISBN码里面最后一个数字原本应该是什么
if(b==10)
b='X';
if(b>=0&&b<=9){
//判断是否相等的时候来了!!!