#include <bits/stdc++.h>
using namespace std;
#define int long long int
#define double long double
const int M = 1000000007;
const int N = 3e5+9;
const int INF = 2e9+1;
const int MAXN = 100000;
const int LINF = 2000000000000000001;
//_ ***************************** START Below *******************************
vector<int> a;
//* Template 1
int consistency1(int n ){
int sum = 0, ans = 0;
unordered_map<int,int> mp;
int s = 0, e = 0;
while(e<n){
mp[a[e]]++;
sum += a[e];
if(mp.size() == e-s+1){
ans = max(ans, sum);
e++;
}
else{
while(s<=e && mp.size() < e-s+1){
mp[a[s]]--;
if(mp[a[s]] == 0) mp.erase(a[s]);
sum -= a[s];
s++;
}
ans = max(ans, sum);
e++;
}
}
return ans;
}
//* Template 2
int consistency2(int n ){
int sum = 0, ans = 0;
unordered_map<int,int> mp;
for(int j=0, i=0; j<n; j++){
mp[a[j]]++;
sum += a[j];
while(i<=j && mp.size() < j-i+1){
mp[a[i]]--;
if(mp[a[i]] == 0) mp.erase(a[i]);
sum -= a[i];
i++;
}
ans = max(ans, sum);
}
return ans;
}
int practice(int n){
return 0;
}
void solve() {
int n;
cin >> n;
a.resize(n);
for(int i=0; i<n; i++) cin >> a[i];
cout << consistency1(n) << " " << consistency2(n) << endl;
// cout << consistency1(n) << " -> " << practice(n) << endl;
}
int32_t main() {
ios_base::sync_with_stdio(0); cin.tie(0); cout.tie(0);
int t = 1;
while (t--) {
solve();
}
return 0;
}
I2luY2x1ZGUgPGJpdHMvc3RkYysrLmg+CnVzaW5nIG5hbWVzcGFjZSBzdGQ7CiNkZWZpbmUgaW50ICAgICAgICAgICAgICBsb25nIGxvbmcgaW50CiNkZWZpbmUgZG91YmxlICAgICAgICAgICBsb25nIGRvdWJsZQoKCmNvbnN0IGludCBNID0gMTAwMDAwMDAwNzsKY29uc3QgaW50IE4gPSAzZTUrOTsKY29uc3QgaW50IElORiA9IDJlOSsxOwpjb25zdCBpbnQgTUFYTiA9IDEwMDAwMDsKY29uc3QgaW50IExJTkYgPSAyMDAwMDAwMDAwMDAwMDAwMDAxOwoKLy9fICoqKioqKioqKioqKioqKioqKioqKioqKioqKioqIFNUQVJUIEJlbG93ICoqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioKCgoKdmVjdG9yPGludD4gYTsKCi8vKiBUZW1wbGF0ZSAxIAoKaW50IGNvbnNpc3RlbmN5MShpbnQgbiApewoJCglpbnQgc3VtID0gMCwgYW5zID0gMDsKCXVub3JkZXJlZF9tYXA8aW50LGludD4gbXA7CgkKCWludCBzID0gMCwgZSA9IDA7Cgl3aGlsZShlPG4pewoJCW1wW2FbZV1dKys7CgkJc3VtICs9IGFbZV07CgkJCgkJaWYobXAuc2l6ZSgpID09IGUtcysxKXsKCQkJYW5zID0gbWF4KGFucywgc3VtKTsKCQkJZSsrOwoJCX0KCQllbHNlewoJCQl3aGlsZShzPD1lICYmIG1wLnNpemUoKSA8IGUtcysxKXsKCQkJCW1wW2Fbc11dLS07CgkJCQlpZihtcFthW3NdXSA9PSAwKSBtcC5lcmFzZShhW3NdKTsKCQkJCXN1bSAtPSBhW3NdOwoJCQkJcysrOwoJCQl9CgkJCWFucyA9IG1heChhbnMsIHN1bSk7CgkJCWUrKzsKCQl9Cgl9CgkKCXJldHVybiBhbnM7CgkKfQoKCgoKCi8vKiBUZW1wbGF0ZSAyIAoKaW50IGNvbnNpc3RlbmN5MihpbnQgbiApewoJCglpbnQgc3VtID0gMCwgYW5zID0gMDsKCXVub3JkZXJlZF9tYXA8aW50LGludD4gbXA7CgkKCWZvcihpbnQgaj0wLCBpPTA7IGo8bjsgaisrKXsKCQltcFthW2pdXSsrOwoJCXN1bSArPSBhW2pdOwoJCQoJCXdoaWxlKGk8PWogJiYgbXAuc2l6ZSgpIDwgai1pKzEpewoJCQltcFthW2ldXS0tOwoJCQlpZihtcFthW2ldXSA9PSAwKSBtcC5lcmFzZShhW2ldKTsKCQkJc3VtIC09IGFbaV07CgkJCWkrKzsKCQl9CgkJYW5zID0gbWF4KGFucywgc3VtKTsKCX0KCQoJcmV0dXJuIGFuczsKCQp9CgoKCgoKCgoKCgoKCgppbnQgcHJhY3RpY2UoaW50IG4pewoJCglyZXR1cm4gMDsJCn0KCgoKCnZvaWQgc29sdmUoKSB7CgoJaW50IG47CgljaW4gPj4gbjsKCWEucmVzaXplKG4pOwoJZm9yKGludCBpPTA7IGk8bjsgaSsrKSBjaW4gPj4gYVtpXTsKCgljb3V0IDw8IGNvbnNpc3RlbmN5MShuKSAgPDwgIiAiIDw8IGNvbnNpc3RlbmN5MihuKSAgPDwgZW5kbDsKCS8vIGNvdXQgPDwgY29uc2lzdGVuY3kxKG4pIDw8ICIgLT4gIiA8PCBwcmFjdGljZShuKSA8PCBlbmRsOwoJCn0KCgoKCgppbnQzMl90IG1haW4oKSB7CiAgICBpb3NfYmFzZTo6c3luY193aXRoX3N0ZGlvKDApOyBjaW4udGllKDApOyBjb3V0LnRpZSgwKTsKCiAgICBpbnQgdCA9IDE7CiAgICB3aGlsZSAodC0tKSB7CiAgICAgICAgc29sdmUoKTsKICAgIH0KCiAgICByZXR1cm4gMDsKfQ==