# include<iostream>
# include<vector>
using namespace std;
void solve(){
int n;
cin >> n;
vector<int> a(n + 1);
for(int i = 0; i < n + 1; i ++){
cin >> a[i];
}
int res = -1e7;
for(int i = 0; i < n; i ++){
if (a[i] + a[i + 1] >= res) res = a[i] + a[i + 1];
}
if (a[n] + a[0] > res) res = a[0] + a[n];
cout << res << endl;
}
int main(){
int t;
cin >> t;
while(t --){
solve();
}
return 0;
}
分析题意可知,当第二次操作后,第三次操作时就会发现,这一次的结果是上一次的队尾做k,上上一次的队尾做队头,在原队列中相邻,可表示为a[i] + a[i + 1],如果将开始的k当作a[0]的话就可以循环a[i] + a[i + 1],知道i<n,因为有n+1个元素最后的下标为n,最后还要比较a[0] + a[n]即最开始的零次。

京公网安备 11010502036488号