题目描述 有一个小球掉落在一串连续的弹簧板上,小球落到某一个弹簧板后,会被弹到某一个地点,直到小球被弹到弹簧板以外的地方。 假设有 n个连续的弹簧板,每个弹簧板占一个单位距离,a[i] 代表代表第 ii 个弹簧板会把小球向前弹 a[i]个距离。比如位置 1的弹簧能让小球前进 2 个距离到达位置 3 。如果小球落到某个弹簧板后,经过一系列弹跳会被弹出弹簧板,那么小球就能从这个弹簧板弹出来。
现在小球掉到了11 号弹簧板上面,那么这个小球会被弹起多少次,才会弹出弹簧板。 1号弹簧板也算一次。
代码实现:
import java.util.Scanner;
public class Main {
public static void main(String[] args) {
Scanner scanner=new Scanner(System.in);
System.out.println("请输入弹簧板的个数:");
int n=scanner.nextInt();
int arr[]= new int[n];
System.out.println("请输入弹簧板的单位距离:");
for(int i=0;i<arr.length;i++){
arr[i]=scanner.nextInt();
}
bounceOut(n,arr);
}
public static void bounceOut(int position, int[] a) {
int sum=0,i=0;
for(i=0;i<a.length;i++){
if(position>sum){
sum+=a[i];
}
if (position<=sum) {
System.out.println(i+1);
break;
}
}
}
}
测试用例:
请输入弹簧板的个数:
5
请输入弹簧板的单位距离:
2
1
2
3
4
3