大整数的因子
大整数的因子
1000ms 65536K
描述:
已知正整数k满足2<=k<=9,现给出长度最大为30位的十进制非负整数c,求所有能整除c的k。
输入:
一个非负整数c,c的位数<=30。
输出:
若存在满足 c%k == 0 的k,从小到大输出所有这样的k,相邻两个数之间用单个空格隔开;若没有这样的k,则输出"none"。
样例输入:
30
样例输出:
2 3 5 6
模拟除法竖式的过程,
从被除数的最高位开始,每一位对除数取余,余数*10加给低一位继续,
直到个位余数为零时即可认为这个数可被k整除
#include <stdio.h>
#include <string.h>
int main()
{
char c[30];
int s[30],len,i,k,dd=0,add,flag=0;
scanf("%s",c);
len=strlen(c);
for(i=0;i<len;i++)
s[i]=c[i]-'0';
for(k=2;k<=9;k++)
{
add=0;
for(i=0;i<len;i++)
//除法竖式,每一位对k求余,余数*10加给下一位继续对k求余,直到最后的余数是0即k可被整除
{
dd=s[i]+add*10;
add=dd%k;
if((i==len-1)&&(add==0))
{
printf("%d ",k);
flag++;//判断是否有输出的k
}
}
}
if(!flag) printf("none");
return 0;
}
版权声明:本文为OrientalGlass原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
THE END