边界值啊边界值,比如说这个测试用例:输入:1-000-00001-0 输出:1-000-00001-X
#include<iostream>
#include<cmath>
#include<algorithm>
#include<cstring>
using namespace std;
int main()
{
string s;
int n=13;
cin>>s;
int sum=0,k=1;
for(int i=0;i<n-2;i++)
{
if(i==1||i==5||i==11)
continue;
sum+=(s[i]-'0')*k;
k++;
}
int id = sum%11;
bool flag = false;
if(id==10)
{
if(s[n-1]=='X')flag = true;
}else
{
if(id==(s[n-1]-'0'))flag = true;
}
if(flag)cout<<"Right"<<endl;
else
{
for(int i=0;i<n-1;i++)
{
cout<<s[i];
}
if(id!=10)
cout<<id<<endl;
else
cout<<"X"<<endl;
}
return 0;
}
第二个边界值啊边界值,比如说这个测试用例:输入:0-670-82162-X 输出:0-670-82162-4
用python写得思路和c++一样,但是在数字比较的时候。c++用的是,s[n-1]-'0',将字符串转化为ascii码进行比较。然而python我用的是int(s[len-1]),字符串‘X’无法转化为int类型的数字,就会报错,所以不能用啊。。。。第二个测试用例就没通过。。。。
s = input()
k=1
sum=0
len = len(s)
for i in range(len-1):
if(s[i]!='-'):
sum += int(s[i])*k
k += 1
mod = sum%11
flag=False
if(mod==10):
if(s[len-1]=='X'):
flag = True
else :
if(s[len-1]!='X'):
if(mod==int(s[len-1])):
flag = True
if(flag):
print('Right')
else :
for i in range(len-1):
print(s[i],end='')
if(mod==10):
print('X')
else :
print(mod)