题目描述
This is the easy version of the problem. The difference between the versions is that the easy version has no swap operations. You can make hacks only if all versions of the problem are solved.
Pikachu is a cute and friendly pokémon living in the wild pikachu herd.
But it has become known recently that infamous team R wanted to steal all these pokémon! Pokémon trainer Andrew decided to help Pikachu to build a pokémon army to resist.
First, Andrew counted all the pokémon — there were exactly n pikachu. The strength of the i-th pokémon is equal to ai, and all these numbers are distinct.
As an army, Andrew can choose any non-empty subsequence of pokemons. In other words, Andrew chooses some array b from k indices such that 1≤b1<b2<⋯<bk≤n, and his army will consist of pokémons with forces ab1,ab2,…,abk.
The strength of the army is equal to the alternating sum of elements of the subsequence; that is, ab1−ab2+ab3−ab4+….
Andrew is experimenting with pokémon order. He performs q operations. In i-th operation Andrew swaps li-th and ri-th pokémon.
Note: q=0 in this version of the task.
Andrew wants to know the maximal stregth of the army he can achieve with the initial pokémon placement. He also needs to know the maximal strength after each operation.
Help Andrew and the pokémon, or team R will realize their tricky plan!
Input
Each test contains multiple test cases.
The first line contains one positive integer t (1≤t≤103) denoting the number of test cases. Description of the test cases follows.
The first line of each test case contains two integers n and q (1≤n≤3⋅105,q=0) denoting the number of pokémon and number of operations respectively.
The second line contains n distinct positive integers a1,a2,…,an (1≤ai≤n) denoting the strengths of the pokémon.
i-th of the last q lines contains two positive integers li and ri (1≤li≤ri≤n) denoting the indices of pokémon that were swapped in the i-th operation.
It is guaranteed that the sum of n over all test cases does not exceed 3⋅105, and the sum of q over all test cases does not exceed 3⋅105.
Output
For each test case, print q+1 integers: the maximal strength of army before the swaps and after each swap.
Note
In third test case we can build an army in such way: [1 2 5 4 3 6 7], its strength will be 5−3+7=9.
样例
3
3 0
1 3 2
2 0
1 2
7 0
1 2 5 4 3 6 7
3
2
9
这题就是在原序列找子序列上升的最大值 和子序列下降的最小值 枚举一遍即可获得答案
如果只找到一个最大值后面成下降序列 输出最大值即可
#include<bits/stdc++.h>
const int maxn = 3e5+10;
using namespace std;
typedef long long ll;
ll a[maxn];
int main()
{
ios::sync_with_stdio(false);
cin.tie(0);cout.tie(0);
int t;
cin>>t;
while(t--)
{
int n,q;
cin>>n>>q;
for(int i=1;i<=n;i++) cin>>a[i];
int j=1;
ll maxi,mini,ans=0;
while(j<=n)
{
maxi=a[j];
while(j+1<=n&&a[j]<a[j+1])
{
j++,maxi=a[j];
}
j++;
if(j>n) break;//后面一定不能让ans+=maxi 因为后面如果成下降序列到结束你的maxi会被+2次
mini=a[j];
while(j+1<=n&&a[j]>a[j+1])
{
j++,mini=a[j];
}
j++;
if(j>n) break;
ans+=maxi-mini;
}
ans+=maxi;
cout<<ans<<endl;
}
return 0;
}