java小算法—球从100米高度自由落下

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

 

思路:

第一次

高度 100

总距离 100

 

第二次

高度 50 

总距离 150

 

第三次 

高度 25

总距离 175

 

...一次类推

 

1.代码

public class Test {

	public static void main(String[] args) {
		
		Mehtod(100, 7);//100米掉下 第7次
	
	}
	
	
	/**
	 * 方法
	 * */
	
	
	public static void Mehtod(double height,int count){
		double countheight=height;
		double currentheight=height;
		if(count>0){
			if(count==1){
				System.out.println("第一次反弹高度----:"+height+"米");
				System.out.println("第一次反弹经过的距离----:"+height+"米");
			}else{
				System.out.println("第一次反弹高度----:"+height+"米");
				System.out.println("第一次反弹经过的距离----:"+height+"米");
				System.out.println("");
				for(int i=2;i<=count;i++){
					currentheight=currentheight/2;
					countheight=countheight+currentheight;
					System.out.println("第"+i+"次反弹高度----:"+currentheight+"米");
					System.out.println("第"+i+"次反弹经过的距离----:"+countheight+"米");
					System.out.println("");
				}
		   }
	  }
  }
	

}

 

 

2.结果

 

 

  • 8
    点赞
  • 31
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
好的,下面是使用递归算法实现的代码: ```c #include <stdio.h> // 递归函数,计算第n落地经过多少 double distance(int n, double h) { if (n == 1) { // 第一落地 return h; } else { // 第n落地 return distance(n - 1, h / 2) * 2 + h; } } // 递归函数,计算第n弹的高度 double height(int n, double h) { if (n == 1) { // 第一落地 return h / 2; } else { // 第n落地 return height(n - 1, h / 2); } } int main() { double h = 100.0; // 初始高度 int n = 10; // 第10落地 double total_distance = distance(n, h); // 第10落地经过多少 double rebound_height = height(n, h); // 第10弹的高度 printf("第10落地经过%.2lf\n", total_distance); printf("第10弹的高度为%.2lf\n", rebound_height); return 0; } ``` 解释一下: - `distance` 函数通过递归计算第 n 落地经过多少。当 n=1 只是落下经过初始高度 h ;当 n>1 落下 h ,然后回原高度一半 h/2 ,再落下 h/2 ,以此类推,直到第 n-1 落地为止,最后再落下 h/2 。因此,第 n 落地,总经过的距离为 `distance(n - 1, h / 2) * 2 + h` 。 - `height` 函数通过递归计算第 n 弹的高度。当 n=1 只是落下,第一弹的高度为初始高度一半 h/2 ;当 n>1 落下 h ,然后回原高度一半 h/2 ,以此类推,直到第 n-1 落地为止,最后弹的高度为 `height(n - 1, h / 2)` 。 - 在 `main` 函数中,初始化初始高度 h 和第 10 落地数 n,然后分别调用 `distance` 和 `height` 函数计算总经过的距离和第 10 弹的高度,并用 `printf` 函数输出结果。 这样,就使用递归算法实现了一球100高度自由落下的问题。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值