CF1572C Paint

Description

You are given a $ 1 $ by $ n $ pixel image. The $ i $ -th pixel of the image has color $ a_i $ . For each color, the number of pixels of that color is at most $ 20 $ . You can perform the following operation, which works like the bucket tool in paint programs, on this image: - pick a color — an integer from $ 1 $ to $ n $ ; - 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.

Input Format

N/A

Output Format

N/A

Explanation/Hint

In the first example, the optimal solution is to apply the operation on the third pixel changing its color to $ 2 $ and then to apply the operation on any pixel that has color $ 2 $ changing its color and the color of all pixels connected to it to $ 1 $ . The sequence of operations is then: $ [1, 2, 3, 2, 1] \to [1, 2, 2, 2, 1] \to [1, 1, 1, 1, 1] $ . In the second example, we can either change the $ 1 $ s to $ 2 $ s in one operation or change the $ 2 $ s to $ 1 $ 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 $ 2 $ .