弹簧板问题~

题目描述 有一个小球掉落在一串连续的弹簧板上,小球落到某一个弹簧板后,会被弹到某一个地点,直到小球被弹到弹簧板以外的地方。 假设有 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

你可能感兴趣的:(算法刷题,java,算法,蓝桥杯,学习)