Posted on 2011-05-02 14:48 
acpeng 阅读(660) 
评论(0)  编辑 收藏 引用  所属分类: 
ACM程序 
			 
			
		 
		OJ地址链接:http://acm.cugb.edu.cn/JudgeOnline/showproblem?problem_id=1022
Description 
若一个整数Y的个位数为X,将X移到最高位得到的恰好是Y的X倍,称Y为一个X倍数。例如,0是一个0倍数,1是一个1倍数。
Input
无
Output
请依次输出最小的0倍数、1倍数、2倍数、……9倍数。每个X倍数输出一行。
Sample Input 
无
Sample Output 
0
1
……
……
……
Hint 
即使是最小的X倍数也可能是一个非常大的整数,甚至远远超出int所能表达的范围。
 
对于X倍数,设定一个数组(事实上应该是字符串,节省空间),第0位赋予初始值k,k=2,3,……9,依次与k相乘得到上一位,即可。注意循环跳出的条件。
代码:
#include<stdio.h>
#include<string.h>
int main()
{
    char str[100]="\0";
    int i,c,j,k;
    printf("0\n1\n");
    for(k=2;k<10;k++)
    {
        str[0]=k+'0';
        i=0;c=0;
        while(1)
        {
            str[i+1]=((str[i]-'0')*k+c)%10+'0';
            c=((str[i]-'0')*k+c)/10;
            i++;
            if((str[i]-'0')*k==k && c==0)
                break;
        }
        for(j=i;j>=0;j--)
        {
            printf("%c",str[j]);
        }
        printf("\n");
        memset(str,0,sizeof(str));
    }
    return 0;
}