面试算法题:一球从100米高度自由落下,每次落地后反跳回原高度的一半;再落下, 求它在 第10次落地时,共经过多少米?第10次反弹多高?

博客讨论了一个数学问题:一球从100米落下,每次反弹回原高度的一半。文章通过类比和数学归纳法找到规律,求出第10次落地时球经过的总距离和第10次反弹的高度。总结的公式为:第n次落地总距离=300-100/pow(2,n-2),并提供了相应的代码实现。" 133182546,19974251,Golang切片逃逸分析与内存优化,"['golang', '后端开发', '编译原理']
摘要由CSDN通过智能技术生成

题目

一球从100米高度自由落下,每次落地后反跳回原高度的一半;再落下,
求它在 第10次落地时,共经过多少米?第10次反弹多高?

思考

做题目不一定总是要只想写程序,要总结规律并结合其他知识。
这个题目可以想象为有一个盆,先往里面放一半水,第二次放一半水的一半水…这个盆永远也不会满。
那么怎么让他满呢?给他加上最后一次放的水的量。
由于第N次放的水的量为b=100/pow(2,n-2);所以前面N次放的水就等于总共的容积(100+100*2)-b

或者说第一次落地经过100(半个来回)
第二次100+100/2*2(半程为100/2)=100+100
第三次100+100(第二个上升和落下)+100/2/2*2(第三次高度减半变成了100/2)

第n次100+100+100/2+100/4+…+100/pow(2,n-2)
第n次距离加上100/pow(2,n-2)等于300
第n次距离=300-100/pow(2,n-2)

直接套用总结的公式就好。

代码

private static void funx()
  • 1
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值