POJ 2498 StuPId(水~)

Description
在DUT 学生们的学号是六位或者七位的数字 但是有一个规律 他们的带权和的末尾总为0
以1390272为例,具体算法如下:
id number : 1 3 9 0 2 7 2
factors : 9 7 3 9 7 3 9
products : 9 21 27 0 14 21 18
其中factors按从后向前937的顺序循环
products=id number*factors
这样9+21+27+0+14+21+18 = 110最后一位为0
现在有一个数字被盖住了 用?表示,让你求这个数字应该是多少,并把整个学号输出
Input
第一行为用例组数,每组用例为一个字符串表示id
Output
对于每组用例,求出?处的数字并把整个学号输出,每组输出后跟一空行
Sample Input
4
13?0272
3?5678
345?78
314?592
Sample Output
Scenario #1:
1390272

Scenario #2:
335678

Scenario #3:
345778

Scenario #4:
3146592

Solution
水题
Code

#include<stdio.h>
#include<string.h>
int main()
{
    int n,i,j,k=1,flag,len,res,a[7]={9,7,3,9,7,3,9},b[6]={7,3,9,7,3,9};
    char id[10];
    scanf("%d",&n);
    getchar();
    while(n)
    {
        res=0;
        gets(id);
        len=strlen(id);
        if(len==6)//6位id 
            for(i=0;i<len;i++)
            {
                if(id[i]!='?')
                    res+=(id[i]-'0')*b[i];
                else//记录?位置 
                    flag=i;
            }
        else if(len=7)//7位id 
            for(i=0;i<len;i++)
            {
                if(id[i]!='?')
                    res+=(id[i]-'0')*a[i];
                else//记录?位置 
                    flag=i;
            }
        for(i=0;i<10;i++)//枚举?处数字 
            if((i*(len==6?b[flag]:a[flag])+res)%10==0)
                id[flag]=i+48;
        printf("Scenario #%d:\n",k);//按格式输出 
        puts(id);
        printf("\n");//按格式输出 
        k++;
        n--;
    }
    return 0;
}

你可能感兴趣的:(POJ 2498 StuPId(水~))