#include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include using namespace std; #define rep(i,n) for(int i = 0;i=0;i--) #define ALL(a) a.begin(),a.end() template inline bool chmax(T& a, T b) { if (a < b) { a = b; return 1; } return 0; } template inline bool chmin(T& a, T b) { if (a > b) { a = b; return 1; } return 0; } typedef long long ll; typedef long double ld; const ll mod = 1e9 + 7; const ll MOD = 998244353; int main() { int n,f,t,s,m; cin >> n;vector a(n); rep(i, n) cin >> a[i]; vector dp(1 << n, 1e9); dp[0] = 0; rep(bit, 1 << n) { int sum = 0; rep(i, n) if ((bit >> i) & 1) sum += a[i]; rep(i, n) { if (!((bit >> i) & 1)) { chmin(dp[bit | (1 << i)],dp[bit]+ max(0,a[i] - (sum % 1000))); } } }cout << dp[(1 << n)-1] << endl; }