#include using namespace std; typedef long long ll; typedef vector vl; typedef vector vvl; typedef pair pll; typedef vector vb; const ll oo = 0x3f3f3f3f3f3f3f3f; const double eps = 1e-9; #define sz(c) ll((c).size()) #define all(c) begin(c), end(c) #define FOR(i,a,b) for (ll i = (a); i < (b); i++) #define FORD(i,a,b) for (ll i = (b)-1; i >= (a); i--) #define mp make_pair #define mt make_tuple #define pb push_back #define eb emplace_back #define xx first #define yy second #define has(c,i) ((c).find(i) != end(c)) #define DBGDO(X) ({ if(1) cerr << "DBGDO: " << (#X) << " = " << (X) << endl; }) int main() { ios_base::sync_with_stdio(false); cin.tie(NULL); ll n; cin >> n; ll res = 0; while (n--) { ll a; cin >> a; vl pf; for (ll p = 2; p*p <= a; p++) { while (a % p == 0) pf.pb(p), a /= p; } if (a > 1) pf.pb(a); ll b = 1; reverse(all(pf)); for (ll p: pf) { res += b; b *= p; } res += b; } cout << res << endl; }