浪潮编程题:石头

浪潮编程题:石头

沙滩按照线型摆放着n个大小不一的球形石头,已知第i个石头的半径为ri,且不存在两个石头有相同的半径。为了使石头的摆放更加美观,现要求摆放的石头的半径从左往右依次递增。因此,需要对一些石头进行移动,每次操作可以选择一个石头,并把它放在剩下n−1个石头在最左边或最右边。问最少需要操作多少次才能将这n个石头的半径变成升序?
使用dp记录以arr[i]结尾的最长连续递增序列


public class 第一道 {
     
    public static void main(String[] args) {
     
        Scanner sc = new Scanner(System.in);
        int n = sc.nextInt();
        int[] arr = new int[n];
        for (int i = 0; i < n; i++) {
     
            arr[i] = sc.nextInt();
        }
        int[] dp = new int[100001];
        int max = 1;
        for (int i = 1; i < n; i++) {
     
            dp[arr[i]] = dp[arr[i]-1]+1;
            max = Math.max(max,dp[arr[i]]); //最大(步长为1)递增序列长度
        }
        System.out.println(n-max);
    }
}

你可能感兴趣的:(算法,java,动态规划,java,算法)