【C语言程序设计】C语言求自守数(详解版)

这篇博客详细介绍了如何使用C语言编程求解100000以内的自守数,通过算法设计和程序流程,展示了如何通过部分积求和截取尾数来找出符合条件的数字。文章提供了完整的代码并展示运行结果,适合编程学习者参考。
摘要由CSDN通过智能技术生成

自守数是指一个数的平方的尾数等于该数自身的自然数。例如:

52 = 25    252 = 625    762 = 5776    93762 = 87909376

求100000以内的自守数。

 

问题分析

根据自守数的定义,求解本题的关键是知道当前所求自然数的位数,以及该数平方的尾数与被乘数、乘数之间的关系。

 

算法设计

若采用“求出一个数的平方后再截取最后相应位数”的方法显然是不可取的,因为计算机无法表示过大的整数。

分析手工方式下整数平方(乘法)的计算过程,以376为例:

本问题所关心的是积的最后三位。分析产生积的后三位的过程可以看出,在每一次的部分积中,并不是它的每一位都会对积的后三位产生影响。总结规律可以得到:在三位数乘法中,对积的后三位产生影响的部分积分别为:

    ✪ 第一个部分积中:被乘数最后三位×乘数的倒数第一位。

    ✪ 第二个部分积中:被乘数最后二位×乘数的倒数第二位。

    ✪ 第三个部分积中:被乘数最后一位×乘数的倒数第三位。

将以上的部分积的后三位求和后,截取后三位就是三位数乘积的后三位,这样的规律可以推广到同样问题的不同位数乘积中。

 

分离给定数中的最后几位

从一个两位数(存在变量n中)开始分析,分离最低位个位n%10

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值