#include using namespace std; #define rep(i, x, limit) for (int i = (int)x; i < (int)limit; i++) #define REP(i, x, limit) for (int i = (int)x; i <= (int)limit; i++) #define all(x) x.begin(), x.end() #define rall(x) x.rbegin(), x.rend() #define el '\n' #define spa " " #define Yes cout << "Yes" << el #define No cout << "No" << el #define YES cout << "YES" << el #define NO cout << "NO" << el #define eps (1e-10) #define Equals(a,b) (fabs((a) - (b)) < eps ) #define debug(x) cerr << #x << " = " << x << el using ll = long long; using ull = unsigned long long; using pii = pair; using pll = pair; using vi = vector; using vl = vector; using vvl = vector>; using vs = vector; using vb = vector; const double pi = 3.141592653589793238; const int inf = 1073741823; const ll infl = 1LL << 60; const string ABC = "ABCDEFGHIJKLMNOPQRSTUVWXYZ"; const string abc = "abcdefghijklmnopqrstuvwxyz"; const ll MOD = 998244353; #include using namespace atcoder; using mint = modint998244353; using vm = vector; // 任意型のベクターをランレングス圧縮して (値, 出現回数) のペア一覧を返す template vector> runLengthEncode(const vector& arr) { vector> result; if (arr.empty()) return result; T prev = arr[0]; int count = 1; for (size_t i = 1; i < arr.size(); ++i) { if (arr[i] == prev) { ++count; } else { result.emplace_back(prev, count); prev = arr[i]; count = 1; } } // 最後のランを追加 result.emplace_back(prev, count); return result; } int main() { ios::sync_with_stdio(false); cin.tie(nullptr); ll n;cin>>n; vl C(n); rep(i,0,n)cin>>C[i]; if(n%2==0){ sort(all(C)); auto rle=runLengthEncode(C); vl stc; for(auto&[a,b]:rle){ if(b%2==1){ stc.push_back(a); } } ll ans=infl; ll len=stc.size(); rep(i,0,1<