浪潮编程题:石头
沙滩按照线型摆放着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);
}
}