[编程题]抛小球

编程题:抛小球

小东和三个朋友一起在楼上抛小球,他们站在楼房的不同层,假设小东站的楼层距离地面N米,球从他手里自由落下,每次落地后反跳回上次下落高度的一半,并以此类推直到全部落到地面不跳,求四个小球一共经历了多少米?(数字都为整数)

给定四个整数A,B,C,D,请返回所求结果。

测试样例:

100,90,80,70

返回:1020


解题要点:以为数字都为整数,所以存在N取偶数还是奇数的问题,如果N是偶数,不会出现差错除以2刚好整除;如果N是奇数,向上取整


第一种方法:递归

package li.gh;

import java.util.Scanner;

public class dsf {
	public static void main(String[] args) {
		Scanner in = new Scanner(System.in);
		int a = in.nextInt();
		int b = in.nextInt();
		int c = in.nextInt();
		int d = in.nextInt();

		System.out.println(fun(a));
		System.out.println(fun(b));
		System.out.println(fun(c));
		System.out.println(fun(d));
		System.out.println(fun(a) + fun(b) + fun(c) + fun(d));

	}

	public static int fun(int a) {
		if (a == 1)
			return 2;
		else {
			if (a % 2 == 0) {
				// return 1;
				// if(a==0) return 0;
				return fun(a / 2) + a;
			} else {
				return fun((a + 1) / 2) + a;
			}
		}

	}


}


第二种方法

package li.gh;

import java.util.Scanner;

public class dsf {
	public static void main(String[] args) {
		Scanner in = new Scanner(System.in);
		int a = in.nextInt();
		int b = in.nextInt();
		int c = in.nextInt();
		int d = in.nextInt();

		System.out.println(getDir(a));
		System.out.println(getDir(b));
		System.out.println(getDir(c));
		System.out.println(getDir(d));
		System.out.println(getDir(a) + getDir(b) + getDir(c) + getDir(d));
	}

	public static int getDir(int n) {
		int s = n;
		while (n > 0) {
			if (n % 2 == 0) {
				s += n;
			} else {
				s += ((n + 1) / 2) * 2;
			}
			n /= 2;
		}
		return s;
	}

}



评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值