**思路:*先画一个图出来,就会发现一个规律,经过的路径长度=上次的总长度+上次的高度+此刻的高度。而此时的高度是newH = h(0.5)^n
初试时h=100米
第一次:lastH = 100 newH = h/2=50 total = total + lastH + newH = 150
第二次:lastH = newH=50 newH=(h/2)/2=25 total = total + lasrH + newH =225
…
以此类推
#include<stdio.h>
#include<math.h>
int main(){
double h=100;
int n;
printf("输入次数:\n");
scanf("%d",&n);
double hn = h*pow(0.5,n);
printf("%d次后的高度为:%f\n",n,hn);
double totalH=0;
double lastH = h;
for(int i=1;i<=n;i++){
double newH = h*pow(0.5,i);
totalH=totalH + lastH + newH;
lastH = newH;
}
printf("%d次经过了%f米\n",n,totalH);
return 0;
}
输出:
此题为了测试方便不仅限于10次的计算。