1049 Counting Ones 解决python超时问题

本文分析了编程之美中的一道题目,探讨如何避免在计算数字中1的个数时引发超时。通过观察1位数、2位数和3位数的情况,总结出计算方法。对于N位数,个位出现1的次数与个位和十位数字有关,而十位和更高位出现1的次数则受到更多因素影响。文章提供了通用的计算策略,以解决此类问题。
摘要由CSDN通过智能技术生成

本题如果直接使用,遍历所有数字中的1的话,会产生超时,因此必须分析其中的规律

 

这道题是编程之美上的一道题

 

先看1位数的情况。

如果= 3,那么从1到3的所有数字:1、2、3,只有个位数字上可能出现1,而且只出现1次,进一步可以发现如果N是个位数,如果N>=1,那么fN)都等于1,如果N=0,则fN)为0。

再看2位数的情况。

 

 

如果N=13,那么从1到13的所有数字:1、2、3、4、5、6、7、8、9、10、11、12、13,个位和十位的数字上都可能有1,我们可以将它们分开来考虑,个位出现1的次数有两次:1和11,十位出现1的次数有4次:10、11、12和13,所以fN)=2+4=6。要注意的是11这个数字在十位和个位都出现了1,但是11恰好在个位为1和十位为1中被计算了两次,所以不用特殊处理,是对的。再考虑N=23的情况,它和N=13有点不同,十位出现1的次数为10次,从10到19,个位出现1的次数为1、11和21,所以fN)=3+10=13。通过对两位数进行分析,我们发现,个位数出现1的次

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值