CCF	2013-12-2 ISBN号码_c++CCF	2013-12-2 ISBN号码_CCF_02

样例输入

0-670-82162-4

样例输出

Right

样例输入

0-670-82162-0

样例输出

0-670-82162-4

CCF	2013-12-2 ISBN号码_c++_03

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;
}