C趣味编程百例(08)自守数

文章作者 100test 发表时间 2007:03:10 17:27:58
来源 100Test.Com百考试题网


27.自守数
自守数是指一个数的平方的尾数等于该数自身的自然数。例如:
252=625 762=5776 93762=87909376
请求出200000以内的自守数
*题目分析与算法设计
若采用“求出一个数的平方后再截取最后相应位数”的方法显然是不可取的,因为计算机无法表示过大的整数。
分析手工方式下整数平方(乘法)的计算过程,以376为例:
376 被乘数
X 376 乘数
----------
2256 第一个部分积=被乘数*乘数的倒数第一位
2632 第二个部分积=被乘数*乘数的倒数第二位
1128 第三个部分积=被乘数*乘数的倒数第三位
----------
141376 积
本问题所关心的是积的最后三位。分析产生积的后三位的过程,可以看出,在每一次的部分积中,并不是它的每一位都会对积的后三位产生影响。总结规律可以得到:在三位数乘法中,对积的后三位产生影响的部分积分别为:
第一个部分积中:被乘数最后三位*乘数的倒数第一位
第二个部分积中:被乘数最后二位*乘数的倒数第二位
第三个部分积中:被乘数最后一位*乘数的倒数第三位
将以上的部分积的后三位求和后截取后三位就是三位数乘积的后三位。这样的规律可以推广到同样问题的不同位数乘积。
按照手工计算的过程可以设计算法编写程序。
*程序说明与注释
#include
void main()
{
long mul,number,k,ll,kk.
printf("It exists following automorphic nmbers small than 200000:\n").
for(number=0.number<200000.number )
{
for(mul=number,k=1.(mul/=10)>0.k*=10).
/*由number的位数确定截取数字进行乘法时的系数k*/
kk=k*10. /*kk为截取部分积时的系数*/
mul=0. /*积的最后n位*/
ll=10. /*ll为截取乘数相应位时的系数*/
while(k>0)
{
mul=(mul (number%(k*10))*(number%ll-number%(ll/10)))%kk.
/*(部分积 截取被乘数的后N位*截取乘数的第M位),%kk再截取部分积*/
k/=10. /*k为截取被乘数时的系数*/
ll*=10.
}
if(number==mul) /*判断若为自守数则输出*/

相关文章


C趣味编程百例(08)求具有abcd=(ab cd)2性质的四位数
天津:2006年下半年NCRE考试查分热线开通
C趣味编程百例(08)自守数
湖南省计算机等级考试的网络操作题要求
C趣味编程百例(08)回文数
上海:06年下半年全国计算机等级考试成绩公布
C趣味编程百例(08)亲密数
澳大利亚华人论坛
考好网
日本华人论坛
华人移民留学论坛
英国华人论坛