이 제출은 이전 버전의 oj.uz에서 채점하였습니다. 현재는 제출 당시와는 다른 서버에서 채점을 하기 때문에, 다시 제출하면 결과가 달라질 수도 있습니다.
#include <bits/stdc++.h>
#define fi first
#define se second
#define pb push_back
#define sz(a) (int)a.size()
#define all(a) a.begin(),a.end()
#define rep(i,n) for(int i=0;i<n;i++)
#define crep(i,x,n) for(int i=x;i<n;i++)
#define drep(i,n) for(int i=n-1;i>=0;i--)
#define vec(...) vector<__VA_ARGS__>
#define _3qplfh5 ios_base::sync_with_stdio(false),cin.tie(0),cout.tie(0)
using namespace std;
typedef long long ll;
typedef long double ld;
using pii=pair<int,int>;
using vi=vector<int>;
using vll=vector<long long>;
int main(){
_3qplfh5;
int n;
cin>>n;
vi a(n);
rep(i,n){
cin>>a[i];
}
sort(all(a));
auto g=[&](vi up,vi dw){
vec(vi) cands;
cands.pb(up);
cands.pb(dw);
rep(t,2){
if(!sz(cands[t]))
return;
}
rep(t,2){
crep(i,2,sz(cands[t])){
if(cands[t][i]-cands[t][i-1]!=cands[t][i-1]-cands[t][i-2])
return;
}
}
rep(t,2){
cout<<sz(cands[t])<<"\n";
for(auto x : cands[t]){
cout<<x<<" ";
}
cout<<"\n";
}
exit(0);
};
auto f=[&](int id,int id2){
vi up,dw;
up.pb(a[id]);
up.pb(a[id2]);
int diff=a[id2]-a[id];
rep(i,n){
if(i==id or i==id2){
continue;
}
int x=a[i];
if(x-up.back()!=diff){
dw.pb(x);
}else{
crep(j,i,n){
dw.pb(a[j]);
}
g(up,dw);
crep(j,i,n) dw.pop_back();
up.pb(x);
}
}
g(up,dw);
};
f(0,1);
f(0,2);
f(1,2);
crep(i,1,sz(a)) assert(a[i]!=a[i-1]);
cout<<"-1\n";
//
return 0;
}
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |