#include <iostream>
#include <algorithm>
using namespace std;
int main()
{
int n;
cin>>n;
int a[1000];
for(int i=0; i<n; i++)
cin>>a[i];
sort(a,a+n);
for(int i=n/2-1; i<n/2+1; i++)
{
int x=0,y=0;
for(int j=i+1; j<n; j++)
{
if(a[i]<a[j])x++;
}
for(int j=i-1; j>=0; j--)
{
if(a[i]>a[j])y++;
}
if(x==y)
{
cout<<a[i];
return 0;
}
}
cout <<-1<< endl;
return 0;
}
思路:推测中间数应该在排序后处于中间位置,所以取最中间3个数往两边进行计算