FastPrepFastPrep
Problem Brief

Maximum Number of Moves with Same Result Sum

FULLTIMEOA
See Google online assessment and hiring insights

You are given an array A consisting of N numbers. In one move you can delete either the first two, the last two, or the first and last elements of A. No move can be performed if the length of A is smaller than 2. The result of each move is the sum of the deleted elements.

Write a function: class Solution { public int solution(int[] A); }

that, given an array A of N integers, returns the maximum number of moves that can be performed on A, such that all performed moves have the same result.

1Example 1

Input
A = [3, 1, 5, 3, 3, 4, 2]
Output
3
Explanation
The first move should delete two last elements (4 and 2 with sum = 6), then A = [3, 1, 5, 3, 3]. The second move may delete first and last elements (3 and 3 with sum = 6), then A = [1, 5, 3]. The third move should delete first two elements (1 and 5 with sum = 6), then A = [3].

2Example 2

Input
A = [4, 1, 4, 3, 3, 2, 5, 2]
Output
4
Explanation
It is possible to delete the first and last elements four times, as each such pair of elements sums up to 6.

3Example 3

Input
A = [1, 9, 1, 1, 1, 1,1,1, 8, 1]
Output
1
Explanation
There is no way to perform move that results with the same sum more than once.

4Example 4

Input
A = [1, 9, 8, 9, 5, 1, 2]
Output
3
Explanation
The first move should delete the first two elements, then the second and third moves should delete first and last elements twice.

5Example 5

Input
A = [1, 1, 2, 3, 1, 2, 2, 1, 1, 2]
Output
4
Explanation
The function should return 4.
public int solution(int[] A) {
  // write your code here
}

Input

A

[3, 1, 5, 3, 3, 4, 2]

Output

3

Sign in to submit your solution.