Paint solution codeforces
You are given a at most .by pixel image. The -th pixel of the image has color . For each color, the number of pixels of that color is
You can perform the following operation, which works like the bucket tool in paint programs, on this image:
- pick a color — an integer from to ;
- choose a pixel in the image;
- for all pixels connected to the selected pixel, change their colors to the selected color (two pixels of the same color are considered connected if all the pixels between them have the same color as those two pixels).
Compute the minimum number of operations needed to make all the pixels in the image have the same color.
Each test contains multiple test cases. The first line contains the number of test cases( ).
The first line of each test case contains a single integer( ) — the number of pixels in the image.
The second line of each test case containsintegers ( ) — the colors of the pixels in the image.
Note: for each color, the number of pixels of that color is at most .
It is guaranteed that the sum ofover all test cases does not exceed .
For each test case, print one integer: the minimum number of operations needed to make all the pixels in the image have the same color.
3 5 1 2 3 2 1 4 1 1 2 2 5 1 2 1 4 2
2 1 3
In the first example, the optimal solution is to apply the operation on the third pixel changing its color toand then to apply the operation on any pixel that has color changing its color and the color of all pixels connected to it to . The sequence of operations is then: .
In the second example, we can either change thes to s in one operation or change the s to s also in one operation.
In the third example, one possible way to make all the pixels have the same color is to apply the operation on the first, third and the fourth pixel each time changing its color to.