概述
样例输入
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;
}
最后
以上就是笨笨睫毛为你收集整理的CCF 2013-12-2 ISBN号码的全部内容,希望文章能够帮你解决CCF 2013-12-2 ISBN号码所遇到的程序开发问题。
如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。
本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
发表评论 取消回复