CF BUDDY
← Problems·

1699D · Almost Triple Deletions

2300 · data structures, dp, greedy

Problem: You are given an integer nn and an array a1,a2,,ana_1,a_2,\ldots,a_n.

In one operation, you can choose an index ii (1i<n1 \le i \lt n) for which aiai+1a_i \neq a_{i+1} and delete both aia_i and ai+1a_{i+1} from the array. After deleting aia_i and ai+1a_{i+1}, the remaining parts of the array are concatenated.

For example, if a=[1,4,3,3,6,2]a=[1,4,3,3,6,2], then after performing an operation with i=2i=2, the resulting array will be [1,3,6,2][1,3,6,2].

What is the maximum possible length of an array of equal elements obtainable from aa by performing several (perhaps none) of the aforementioned operations?

Input Format: Each test contains multiple test cases. The first line of input contains one integer tt (1t10001 \le t \le 1000) — the number of test cases. The following lines contain the descriptions of the test cases.

The first line of each test case contains a single integer nn (1n50001 \le n \le 5000) — the length of array aa.

The second line of each test case contains nn integers a1,a2,,ana_1,a_2,\ldots,a_n (1ain1 \le a_i \le n) — the elements of array aa.

It is guaranteed that the sum of nn across all test cases does not exceed 1000010\,000.

Output Format: For each testcase, print a single integer, the maximum possible length of an array of equal elements obtainable from aa by performing a sequence of operations.

Note: For the first testcase, an optimal sequence of operations would be: [1,2,3,2,1,3,3][3,2,1,3,3][3,3,3][1,2,3,2,1,3,3] \rightarrow [3,2,1,3,3] \rightarrow [3,3,3].

For the second testcase, all elements in the array are already equal.

For the third testcase, the only possible sequence of operations is: [1,1,1,2,2,2][1,1,2,2][1,2][][1,1,1,2,2,2] \rightarrow [1,1,2,2] \rightarrow [1,2] \rightarrow []. Note that, according to the statement, the elements deleted at each step must be different.

For the fourth testcase, the optimal sequence of operations is: [1,1,2,2,3,3,1,1][1,1,2,3,1,1][1,1,1,1][1,1,2,2,3,3,1,1] \rightarrow [1,1,2,3,1,1] \rightarrow [1,1,1,1].

For the fifth testcase, one possible reachable array of two equal elements is [4,4][4,4].

Sample Cases

Case 1

Input

5
7
1 2 3 2 1 3 3
1
1
6
1 1 1 2 2 2
8
1 1 2 2 3 3 1 1
12
1 5 2 3 3 3 4 4 4 4 3 3

Output

3
1
0
4
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