//#pragma GCC optimize("O3", "unroll-loops")
//#pragma GCC target("avx2", "bmi", "bmi2", "lzcnt", "popcnt")
#include <bits/stdc++.h>
#define ldb long double
//#define double ldb
#define db double
#define unomap unordered_map
#define unoset unordered_set
#define endl '\n'
#define str string
#define strstr stringstream
#define sz(a) (int)a.size()
#define ll long long
#define int ll
#define pii pair <int, int>
#define pll pair <ll, ll>
#define Unique(a) a.resize(unique(all(a)) - a.begin())
#define ull unsigned ll
#define fir first
#define sec second
#define idc cin.ignore()
#define lb lower_bound
#define ub upper_bound
#define all(s) s.begin(), s.end()
#define rev reverse
#define gcd __gcd
#define pushb push_back
#define popb pop_back
#define pushf push_front
#define popf pop_front
#define mul2x(a, x) a << x
#define div2x(a, x) a >> x
#define lcm(a, b) (a / __gcd(a, b) * b)
#define log_base(x, base) log(x) / log(base)
#define debug cerr << "No errors!"; exit(0);
#define forw(i, a, b) for (int i = a; i <= b; ++i)
#define forw2(i, a, b) for (ll i = a; i <= b; ++i)
#define fors(i, a, b) for (int i = a; i >= b; --i)
#define fors2(i, a, b) for (ll i = a; i >= b; --i)
#define pqueue priority_queue
#define sqrt sqrtl
#define i128 __int128
#define popcount __builtin_popcountll
#define BIT(x, i) (((x) >> (i)) & 1)
#define MASK(x) ((1LL) << (x))
#define want_digit(x) cout << fixed << setprecision(x);
#define excuting_time 1000.0 * clock() / CLOCKS_PER_SEC
using namespace std;
const int MOD = 1e9 + 7; // 998244353
const int inf = 1e9;
const ll INF = 1e18;
const int N = 5e4;
mt19937_64 rng(chrono::steady_clock::now().time_since_epoch().count());
ll random(const ll &L, const ll &R) {
return uniform_int_distribution<ll> (L, R) (rng);
}
int n, p[N + 5], sum[N + 5];
ll ans, preMin[N + 5], sufMin[N + 5];
int get(int l, int r) {
return sum[r] - sum[l - 1];
}
ll square(int x) {
return x * 1LL * x;
}
void solve() {
cin >> n;
forw (i, 1, n) {
cin >> p[i];
sum[i] = sum[i - 1] + p[i];
}
forw (i, 0, n) preMin[i] = INF;
forw (i, 0, n + 1) sufMin[i] = INF;
forw (y, 2, n - 2) {
ll curMin = INF;
forw (x, 1, y - 1) {
ll A = get(1, x);
ll B = get(x + 1, y);
ll val = square(A) + square(B);
if (val < curMin) curMin = val;
}
preMin[y] = curMin;
}
fors (y, n - 2, 2) {
ll curMin = INF;
forw (z, y + 1, n - 1) {
ll C = get(y + 1, z);
ll D = get(z + 1, n);
ll val = square(C) + square(D);
if (val < curMin) curMin = val;
}
sufMin[y] = curMin;
}
ll ans = INF;
forw (y, 2, n - 2) {
if (preMin[y] == INF || sufMin[y] == INF) continue;
ll val = preMin[y] * sufMin[y];
if (val < ans) ans = val;
}
cout << ans << endl;
}
signed main() {
ios::sync_with_stdio(false), cin.tie(nullptr);
srand(time(NULL));
#define name "test"
if (fopen(name".INP", "r")) {
freopen(name".INP", "r", stdin);
freopen(name".OUT", "w", stdout);
}
bool testCase = false;
int numTest = 1;
// cin >> numTest;
forw (i, 1, numTest) {
if (testCase) cout << "Case " << i << ": ";
solve();
}
return 0;
}
Ly8jcHJhZ21hIEdDQyBvcHRpbWl6ZSgiTzMiLCAidW5yb2xsLWxvb3BzIikKLy8jcHJhZ21hIEdDQyB0YXJnZXQoImF2eDIiLCAiYm1pIiwgImJtaTIiLCAibHpjbnQiLCAicG9wY250IikKCiNpbmNsdWRlIDxiaXRzL3N0ZGMrKy5oPgojZGVmaW5lIGxkYiBsb25nIGRvdWJsZQovLyNkZWZpbmUgZG91YmxlIGxkYgojZGVmaW5lIGRiIGRvdWJsZQojZGVmaW5lIHVub21hcCB1bm9yZGVyZWRfbWFwCiNkZWZpbmUgdW5vc2V0IHVub3JkZXJlZF9zZXQKI2RlZmluZSBlbmRsICdcbicKI2RlZmluZSBzdHIgc3RyaW5nCiNkZWZpbmUgc3Ryc3RyIHN0cmluZ3N0cmVhbQojZGVmaW5lIHN6KGEpIChpbnQpYS5zaXplKCkKI2RlZmluZSBsbCBsb25nIGxvbmcKI2RlZmluZSBpbnQgbGwKI2RlZmluZSBwaWkgcGFpciA8aW50LCBpbnQ+CiNkZWZpbmUgcGxsIHBhaXIgPGxsLCBsbD4KI2RlZmluZSBVbmlxdWUoYSkgYS5yZXNpemUodW5pcXVlKGFsbChhKSkgLSBhLmJlZ2luKCkpCiNkZWZpbmUgdWxsIHVuc2lnbmVkIGxsCiNkZWZpbmUgZmlyIGZpcnN0CiNkZWZpbmUgc2VjIHNlY29uZAojZGVmaW5lIGlkYyBjaW4uaWdub3JlKCkKI2RlZmluZSBsYiBsb3dlcl9ib3VuZAojZGVmaW5lIHViIHVwcGVyX2JvdW5kCiNkZWZpbmUgYWxsKHMpIHMuYmVnaW4oKSwgcy5lbmQoKQojZGVmaW5lIHJldiByZXZlcnNlCiNkZWZpbmUgZ2NkIF9fZ2NkCiNkZWZpbmUgcHVzaGIgcHVzaF9iYWNrCiNkZWZpbmUgcG9wYiBwb3BfYmFjawojZGVmaW5lIHB1c2hmIHB1c2hfZnJvbnQKI2RlZmluZSBwb3BmIHBvcF9mcm9udAojZGVmaW5lIG11bDJ4KGEsIHgpIGEgPDwgeAojZGVmaW5lIGRpdjJ4KGEsIHgpIGEgPj4geAojZGVmaW5lIGxjbShhLCBiKSAoYSAvIF9fZ2NkKGEsIGIpICogYikKI2RlZmluZSBsb2dfYmFzZSh4LCBiYXNlKSBsb2coeCkgLyBsb2coYmFzZSkKI2RlZmluZSBkZWJ1ZyBjZXJyIDw8ICJObyBlcnJvcnMhIjsgZXhpdCgwKTsKI2RlZmluZSBmb3J3KGksIGEsIGIpIGZvciAoaW50IGkgPSBhOyBpIDw9IGI7ICsraSkKI2RlZmluZSBmb3J3MihpLCBhLCBiKSBmb3IgKGxsIGkgPSBhOyBpIDw9IGI7ICsraSkKI2RlZmluZSBmb3JzKGksIGEsIGIpIGZvciAoaW50IGkgPSBhOyBpID49IGI7IC0taSkKI2RlZmluZSBmb3JzMihpLCBhLCBiKSBmb3IgKGxsIGkgPSBhOyBpID49IGI7IC0taSkKI2RlZmluZSBwcXVldWUgcHJpb3JpdHlfcXVldWUKI2RlZmluZSBzcXJ0IHNxcnRsCiNkZWZpbmUgaTEyOCBfX2ludDEyOAojZGVmaW5lIHBvcGNvdW50IF9fYnVpbHRpbl9wb3Bjb3VudGxsCiNkZWZpbmUgQklUKHgsIGkpICgoKHgpID4+IChpKSkgJiAxKQojZGVmaW5lIE1BU0soeCkgKCgxTEwpIDw8ICh4KSkKI2RlZmluZSB3YW50X2RpZ2l0KHgpIGNvdXQgPDwgZml4ZWQgPDwgc2V0cHJlY2lzaW9uKHgpOwojZGVmaW5lIGV4Y3V0aW5nX3RpbWUgMTAwMC4wICogY2xvY2soKSAvIENMT0NLU19QRVJfU0VDCnVzaW5nIG5hbWVzcGFjZSBzdGQ7CmNvbnN0IGludCBNT0QgPSAxZTkgKyA3OyAvLyA5OTgyNDQzNTMKY29uc3QgaW50IGluZiA9IDFlOTsKY29uc3QgbGwgSU5GID0gMWUxODsKY29uc3QgaW50IE4gPSA1ZTQ7CgptdDE5OTM3XzY0IHJuZyhjaHJvbm86OnN0ZWFkeV9jbG9jazo6bm93KCkudGltZV9zaW5jZV9lcG9jaCgpLmNvdW50KCkpOwpsbCByYW5kb20oY29uc3QgbGwgJkwsIGNvbnN0IGxsICZSKSB7CiAgICByZXR1cm4gdW5pZm9ybV9pbnRfZGlzdHJpYnV0aW9uPGxsPiAoTCwgUikgKHJuZyk7Cn0KCmludCBuLCBwW04gKyA1XSwgc3VtW04gKyA1XTsKbGwgYW5zLCBwcmVNaW5bTiArIDVdLCBzdWZNaW5bTiArIDVdOwppbnQgZ2V0KGludCBsLCBpbnQgcikgewogICAgcmV0dXJuIHN1bVtyXSAtIHN1bVtsIC0gMV07Cn0KCmxsIHNxdWFyZShpbnQgeCkgewogICAgcmV0dXJuIHggKiAxTEwgKiB4Owp9Cgp2b2lkIHNvbHZlKCkgewogICAgY2luID4+IG47CiAgICBmb3J3IChpLCAxLCBuKSB7CiAgICAgICAgY2luID4+IHBbaV07CiAgICAgICAgc3VtW2ldID0gc3VtW2kgLSAxXSArIHBbaV07CiAgICB9CgogICAgZm9ydyAoaSwgMCwgbikgcHJlTWluW2ldID0gSU5GOwogICAgZm9ydyAoaSwgMCwgbiArIDEpIHN1Zk1pbltpXSA9IElORjsKCiAgICBmb3J3ICh5LCAyLCBuIC0gMikgewogICAgICAgIGxsIGN1ck1pbiA9IElORjsKICAgICAgICBmb3J3ICh4LCAxLCB5IC0gMSkgewogICAgICAgICAgICBsbCBBID0gZ2V0KDEsIHgpOwogICAgICAgICAgICBsbCBCID0gZ2V0KHggKyAxLCB5KTsKICAgICAgICAgICAgbGwgdmFsID0gc3F1YXJlKEEpICsgc3F1YXJlKEIpOwogICAgICAgICAgICBpZiAodmFsIDwgY3VyTWluKSBjdXJNaW4gPSB2YWw7CiAgICAgICAgfQogICAgICAgIHByZU1pblt5XSA9IGN1ck1pbjsKICAgIH0KCiAgICBmb3JzICh5LCBuIC0gMiwgMikgewogICAgICAgIGxsIGN1ck1pbiA9IElORjsKICAgICAgICBmb3J3ICh6LCB5ICsgMSwgbiAtIDEpIHsKICAgICAgICAgICAgbGwgQyA9IGdldCh5ICsgMSwgeik7CiAgICAgICAgICAgIGxsIEQgPSBnZXQoeiArIDEsIG4pOwogICAgICAgICAgICBsbCB2YWwgPSBzcXVhcmUoQykgKyBzcXVhcmUoRCk7CiAgICAgICAgICAgIGlmICh2YWwgPCBjdXJNaW4pIGN1ck1pbiA9IHZhbDsKICAgICAgICB9CiAgICAgICAgc3VmTWluW3ldID0gY3VyTWluOwogICAgfQoKICAgIGxsIGFucyA9IElORjsKICAgIGZvcncgKHksIDIsIG4gLSAyKSB7CiAgICAgICAgaWYgKHByZU1pblt5XSA9PSBJTkYgfHwgc3VmTWluW3ldID09IElORikgY29udGludWU7CiAgICAgICAgbGwgdmFsID0gcHJlTWluW3ldICogc3VmTWluW3ldOwogICAgICAgIGlmICh2YWwgPCBhbnMpIGFucyA9IHZhbDsKICAgIH0KCiAgICBjb3V0IDw8IGFucyA8PCBlbmRsOwp9CgpzaWduZWQgbWFpbigpIHsKICAgIGlvczo6c3luY193aXRoX3N0ZGlvKGZhbHNlKSwgY2luLnRpZShudWxscHRyKTsKICAgIHNyYW5kKHRpbWUoTlVMTCkpOwogICAgI2RlZmluZSBuYW1lICJ0ZXN0IgogICAgaWYgKGZvcGVuKG5hbWUiLklOUCIsICJyIikpIHsKICAgICAgICBmcmVvcGVuKG5hbWUiLklOUCIsICJyIiwgc3RkaW4pOwogICAgICAgIGZyZW9wZW4obmFtZSIuT1VUIiwgInciLCBzdGRvdXQpOwogICAgfQogICAgYm9vbCB0ZXN0Q2FzZSA9IGZhbHNlOwogICAgaW50IG51bVRlc3QgPSAxOwovLyAgICBjaW4gPj4gbnVtVGVzdDsKICAgIGZvcncgKGksIDEsIG51bVRlc3QpIHsKICAgICAgICBpZiAodGVzdENhc2UpIGNvdXQgPDwgIkNhc2UgIiA8PCBpIDw8ICI6ICI7CiAgICAgICAgc29sdmUoKTsKICAgIH0KICAgIHJldHVybiAwOwp9Cg==