A. Maximum Cake Tastiness
There are pieces of cake on a line. The -th piece of cake has weight ().
The tastiness of the cake is the maximum total weight of two adjacent pieces of cake (i. e., ).
You want to maximize the tastiness of the cake. You are allowed to do the following operation at most once (doing more operations would ruin the cake):
- Choose a contiguous subsegment of pieces of cake (), and reverse it.
The subsegment of the array is the sequence .
If you reverse it, the array will become .
For example, if the weights are initially , you can reverse the subsegment , getting . The tastiness of the cake is now (while before the operation the tastiness was ).
Find the maximum tastiness of the cake after doing the operation at most once.
The first line contains a single integer () — the number of test cases.
The first line of each test case contains a single integer () — the number of pieces of cake.
The second line of each test case contains integers () — is the weight of the -th piece of cake.
For each test case, print a single integer: the maximum tastiness of the cake after doing the operation at most once.
5
6
5 2 1 4 7 3
3
32 78 78
3
69 54 91
8
999021 999021 999021 999021 999652 999021 999021 999021
2
1000000000 1000000000
12
156
160
1998673
2000000000
In the first test case, after reversing the subsegment , you get a cake with weights . The tastiness of the cake is now . This is the maximum possible tastiness of the cake one can obtain by performing the operation at most once.
In the second test case, it's optimal not to do any operation. The tastiness is .
In the third test case, after reversing the subsegment , you get a cake with weights . The tastiness of the cake is now . There is no way to make the tastiness of the cake greater than by performing at most one operation.
solution:
#include<iostream>
#include<vector>
#include<algorithm>
using namespace std;
int main()
{
int t;
cin >> t;
for (int j = 0; j < t; j++)
{
int n;
cin >> n;
vector<int> v(n);
for (int i = 0; i < n; i++) cin >> v[i];
sort(v.begin(), v.end(), greater<int>());
int max;
max = v[0] + v[1];
cout << max << "\n";
}
return 0;
}
No comments:
Post a Comment