O(N) 桶排序
#include "bits/stdc++.h"
using namespace std;
int m[101]={};
int main(){
int n;
cin>>n;
for(int i=0;i<n;i++){
int v;cin>>v;
m[v]++;
}
int l=0,r=100,mx=2,mn=200;
while(l<=r){
if(m[l]==0){
l++;
continue;
}
if(m[r]==0){
r--;
continue;
}
int mm=min(m[l],m[r]);
m[l]-=mm;if(l!=r)m[r]-=mm;
mx=max(mx,r+l);
mn=min(r+l,mn);
//cout<<r<<" "<<l<<" "<<mx<<" "<<mn<<endl;
}
cout<<mx-mn;
}
京公网安备 11010502036488号