Brackets

Indian National Olympiad in Informatics 2016
There are k types of brackets each with its own opening bracket and closing bracket. We assume that the first pair is denoted by the numbers 1 and k+1, the second by 2 and k+2 and so on. Thus the opening brackets are denoted by 1,2,.., k, and the corresponding closing brackets are denoted by k+1,k+2,..., 2*k respectively.Some sequences with elements from 1,2, ... 2*k form wellbracketed sequences while others don't. A sequence is wellbracketed, if we can match or pair up opening brackets and closing brackets of the same type in such a way that the following holds:
1) every bracket is paired up
2) in each matched pair, the opening bracket occurs before the closing bracket
3) for a matched pair, any other matched pair lies either completely between them or outside them.
For the examples discussed below, let us assume that k = 2. The sequence 1,1,3 is not wellbracketed as one of the two 1's cannot be paired. The sequence 3,1,3,1 is not wellbracketed as there is no way to match the second 1 to a closing bracket occurring after it. The sequence 1,2,3,4 is not wellbracketed as the matched pair 2,4 is neither completely between the matched pair 1,3 nor completely outside it. That is, the matched pairs cannot overlap. The sequence 1,2,4,3,1,3 is wellbracketed. We match the first 1 with the first 3, the 2 with the 4 and the second 1 with the second 3, satisfying all the 3 conditions. If you rewrite these sequences using [,{,],} instead of 1,2,3,4 respectively, this will be quite clear.
In this problem you are given a sequence of brackets, of length N: B[1], .., B[N], where each B[i] is one of the brackets. You are also given an array of Values: V[1],.., V[N].
Among all the subsequences in the Values array, such that the corresponding bracket subsequence in the B Array is a wellbracketed sequence, you need to find the maximum sum. Suppose N = 6, k = 3 and the values of V and B are as follows:
i 1 2 3 4 5 6 V[i] 4 5 2 1 1 6 B[i] 1 3 4 2 5 6
Then, the brackets in positions 1,3 form a wellbracketed sequence (1,4) and the sum of the values in these positions is 2 (4 + 2 = 2). The brackets in positions 1,3,4,5 form a wellbracketed sequence (1,4,2,5) and the sum of the values in these positions is 4. Finally, the brackets in positions 2,4,5,6 forms a wellbracketed sequence (3,2,5,6) and the sum of the values in these positions is 13. The sum of the values in positions 1,2,5,6 is 16 but the brackets in these positions (1,3,5,6) do not form a wellbracketed sequence. You can check the best sum from positions whose brackets form a wellbracketed sequence is 13.
Input format
One line, which contains (2*N + 2) space separate integers. The first integer denotes N. The next integer is k. The next N integers are V[1],..., V[N]. The last N integers are B[1],.., B[N].
Output format
One integer, which is the maximum sum possible satisfying the requirement mentioned above.
Test data
1 ≤ k ≤ 7
10^{6} ≤ V[i] ≤ 10^{6}, for all i
1 ≤ B[i] ≤ 2*k, for all i.
Subtask 1 (40 Marks) 1 ≤ n ≤ 10.
Subtask 2 (60 Marks) 1 ≤ n ≤ 700.
Sample Input
6 3 4 5 2 1 1 6 1 3 4 2 5 6
Sample Output
13
Author:  anukul 
Date Added:  22042016 
Time Limit:  1 sec 
Source Limit:  50000 Bytes 
Languages:  C, C99 strict, CPP 4.3.2, CPP 4.9.2, CPP14, JAVA, PYTH, PYTH 3.4 
Comments
 Please login at the top to post a comment.
SUCCESSFUL SUBMISSIONS
Fetching successful submissions