CF BUDDY
← Problems·

1367F1 · Flying Sort (Easy Version)

2100 · dp, greedy, two pointers

Problem: This is an easy version of the problem. In this version, all numbers in the given array are distinct and the constraints on nn are less than in the hard version of the problem.

You are given an array aa of nn integers (there are no equals elements in the array). You can perform the following operations on array elements:

  1. choose any index ii (1in1 \le i \le n) and move the element a[i]a[i] to the begin of the array;
  2. choose any index ii (1in1 \le i \le n) and move the element a[i]a[i] to the end of the array.

For example, if n=5n = 5, a=[4,7,2,3,9]a = [4, 7, 2, 3, 9], then the following sequence of operations can be performed:

  • after performing the operation of the first type to the second element, the array aa will become [7,4,2,3,9][7, 4, 2, 3, 9];
  • after performing the operation of the second type to the second element, the array aa will become [7,2,3,9,4][7, 2, 3, 9, 4].

You can perform operations of any type any number of times in any order.

Find the minimum total number of operations of the first and second type that will make the aa array sorted in non-decreasing order. In other words, what is the minimum number of operations that must be performed so the array satisfies the inequalities a[1]a[2]a[n]a[1] \le a[2] \le \ldots \le a[n].

Input Format: The first line contains a single integer tt (1t1001 \le t \le 100) — the number of test cases in the test. Then tt test cases follow.

Each test case starts with a line containing an integer nn (1n30001 \le n \le 3000) — length of the array aa.

Then follow nn integers a1,a2,,ana_1, a_2, \ldots, a_n (0ai1090 \le a_i \le 10^9) — an array that needs to be sorted by the given operations. All numbers in the given array are distinct.

The sum of nn for all test cases in one test does not exceed 30003000.

Output Format: For each test case output one integer — the minimum total number of operations of the first and second type, which will make the array sorted in non-decreasing order.

Note: In the first test case, you first need to move 3, and then 2 to the beginning of the array. Therefore, the desired sequence of operations: [4,7,2,3,9][3,4,7,2,9][2,3,4,7,9][4, 7, 2, 3, 9] \rightarrow [3, 4, 7, 2, 9] \rightarrow [2, 3, 4, 7, 9].

In the second test case, you need to move the 1 to the beginning of the array, and the 8 — to the end. Therefore, the desired sequence of operations: [3,5,8,1,7][1,3,5,8,7][1,3,5,7,8][3, 5, 8, 1, 7] \rightarrow [1, 3, 5, 8, 7] \rightarrow [1, 3, 5, 7, 8].

In the third test case, the array is already sorted.

Sample Cases

Case 1

Input

4
5
4 7 2 3 9
5
3 5 8 1 7
5
1 4 5 7 12
4
0 2 1 3

Output

2
2
0
2

Similar problems

00:00:00
Loading editor…
Welcome! I'm your coding tutor for this problem. Use the chips below to reveal stored hints or get AI feedback on your code. I'll guide you step by step — never giving away the solution.

Sign in to unlock AI tutor feedback