链接:https://codeforces.com/problemset/problem/1833/D
题面:
细节:分类讨论
约定记号:a,b[c,d],e,f:选定cd为反向序列
。
①当最大值出现在最后一个元素
可以确定:必然的形式是[a,...,p],maxn
,右括号位置一定不变,那么就移动左括号,逐步后移,看反转后的大小。
②当最大值出现在中间
必然的形式:[a,b,c,d],maxn,e,f,g
此时如情况1,右括号一定不变,就改变左括号即可,同时maxn右边的序列一定保持原样。
③当最大值出现在首位
此时我们还需要一个参量就是次大值:maxnSecond.
当maxnSecond出现在最后一位
形如:maxn,a,b,c,d,maxnSecond
那么显然maxn,[a,b,c,d],maxnSecond
同样只能改变左括号的位置,化为情况1。
当maxnSecond出现在中间
形如:maxn,a,b,c,d,maxnSecond,e,f,g
那么也是一样的,同上。
代码:
#include<iostream>
#include<vector>
#include<algorithm>
#include<math.h>
#include<sstream>
#include<string>
#include<string.h>
#include<iomanip>
#include<stdlib.h>
#include<map>
#include<queue>
#include<cmath>
#include<limits.h>
#include<climits>
#include<fstream>
#include<set>
typedef long long ll;
using namespace std;
const int N = 2e3 + 10;
int lst[N];
int main()
{
ios::sync_with_stdio(false);
cin.tie(0), cout.tie(0);
int t; cin >> t;
while (t--)
{
int n; cin >> n;
int pid = 0;
int pidsec = 0;
for (int i = 1; i <= n; i++) { cin >> lst[i]; if (lst[i] == n)pid = i; if (lst[i] == n - 1)pidsec = i; }
if (n > 1)//只有n大于1进入循环
{
if (pid == 1)
{
if (pidsec == n)
{
cout << lst[n] << ' ';
for (int i = 1; i < n; i++)
{
cout << lst[i] << ' ';
}
cout << '\n';
}
else
{
for (int i = pidsec; i <= n; i++)cout << lst[i] << ' ';
cout << lst[pidsec - 1] << ' ';
for (int i = 1; i < pidsec - 1; i++)cout << lst[i] << ' ';
cout << '\n';
}
}
else if (pid > 1 and pid < n)
{
pidsec = pid - 1;
for (int i = pid - 2; i >= 1; i--)
{
if (lst[i] < lst[1])break;
else pidsec = i;
}
for (int i = pid; i <= n; i++)cout << lst[i] << ' ';
for (int i = pid - 1; i >= pidsec; i--)cout << lst[i] << ' ';
for (int i = 1; i < pidsec; i++)cout << lst[i] << ' ';
cout << '\n';
}
else
{
pidsec = n;
for (int i = n - 1; i > 1; i--)
{
if (lst[i] < lst[1])break;
else pidsec = i;
}
for (int i = pid; i >= pidsec; i--)cout << lst[i] << ' ';
for (int i = 1; i < pidsec; i++)cout << lst[i] << ' ';
cout << '\n';
}
}
else cout << lst[1] << '\n';
}
return 0;
}
标签:int,pid,maxnSecond,lst,pidsec,Flipper,include
From: https://www.cnblogs.com/zzzsacmblog/p/18184543