样例输入
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:
复制代码
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51#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:
复制代码
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34#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内容请搜索靠谱客的其他文章。
本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
发表评论 取消回复