重庆分公司,新征程启航
为企业提供网站建设、域名注册、服务器等服务
#include stdio.h
创新互联建站提供网站建设、做网站、网页设计,成都品牌网站建设,一元广告等致力于企业网站建设与公司网站制作,十载的网站开发和建站经验,助力企业信息化建设,成功案例突破上1000+,是您实现网站建设的好选择.
int main()
{
int m,n;
printf("输入m,n:");
while(1)
{
scanf("%d %d",m,n);
if(m=10||m=200000 || n=10||n=200000)
printf("输入错误,请重新输入:\n");
else
break;
}
if(mn)
{
m-=n;
n+=m;
m=n-m;
}
printf("%d到%d之间的自守数有:\n",m,n);
int i;
int temp;
int count=0;
while(m=n)
{
temp = m*(m-1);
i=1;
while(i=m)
i*=10;
if(temp%i==0)
{
count++;
printf("%7d",m);
if(count%5==0)
printf("\n");
}
m++;
}
printf("\n");
return 0;
}
#include int main(){
long mul,number,k,ll,kk;scanf("%ld",number);for(mul=number,k=1;(mul/=10)0;k*=10);/*由number的位数确定截取数字进行乘法时的系数k*/kk=k*10; /*kk为截取部分积时的系数*/mul=0; /*积的最后n位*/ll=10; /*ll为截取乘数相应位时的系数*/while(k0){mul=(mul+(number%(k*10))*(number%ll-number%(ll/10)))%kk;/*(部分积+截取被乘数的后N位*截取乘数的第M位),%kk再截取部分积*/k/=10; /*k为截取被乘数时的系数*/ll*=10;}if(number==mul) /*判断若为自守数则输出*/printf("%ld 是自守数",number);elseprintf("%ld 不是自守数",number);}
#include stdio.hint main(){
long mul,number,k,ll,kk;scanf("%ld",number);for(mul=number,k=1;(mul/=10)0;k*=10);/*由number的位数确定截取数字进行乘法时的系数k*/kk=k*10; /*kk为截取部分积时的系数*/mul=0; /*积的最后n位*/ll=10; /*ll为截取乘数相应位时的系数*/while(k0){mul=(mul+(number%(k*10))*(number%ll-number%(ll/10)))%kk;/*(部分积+截取被乘数的后N位*截取乘数的第M位),%kk再截取部分积*/k/=10; /*k为截取被乘数时的系数*/ll*=10;}if(number==mul) /*判断若为自守数则输出*/printf("%ld 是自守数",number);elseprintf("%ld 不是自守数",number);}
主函数如下写就可以了。但我看着你的自定义函数是错误的——
int main(int argc,char *argv[]){
int n,t;
for(t=0,n=1;n10000;n++)
if(isAutomorphic(n))
printf(++t%5 ? "%8d" : "%8d\n",n);
printf("\n");
return 0;
}
#includestdio.h
void main()
{
int x,y,z;
scanf("%d",x);
y=x*x;
z=y-x;
if (z%10==0)
printf("%d yes %d",x,y);
else
printf("%d no %d",x,y);
}
上一步k值为log10(i)+1,即变量i十进制表示的位数
通过累乘,将m值赋值为为i的十进制最高位的表示,用于下面的a%=m
如i值为[100,999]区间,则m=100;i值为[10,99]区间,则m=10