#include using namespace std; using Int32 = int_fast32_t; using Word32 = uint_fast32_t; using Int64 = int_fast64_t; using Word64 = uint_fast64_t; using Int128 = __int128_t; using Word128 = __uint128_t; using Int = int_fast64_t; using Word = uint_fast64_t; using F32 = float; using F64 = double; using F80 = long double; using VInt = vector; using VVI = vector; using VWord = vector; using VVW = vector; using VF32 = vector; using VF64 = vector; using VF80 = vector; using VS = vector; using VVS = vector; using VB = vector; using VVB = vector; using PII = pair; using PWW = pair; using VPII = vector; using VPWW = vector; using PQ_PII = priority_queue>; #define SZ(x) ((Int)(x).size()) #define UNIQUE(v) v.erase(unique(v.begin(), v.end()), v.end()) #define rep(i,n) for(Int i=0, i##_len=(n); i> n; VF80 v(n); priority_queue> pq; rep(i,n) { cin >> v[i]; pq.push(mp(v[i],1)); } VF80 K(500001); for (Int i = 1; i <= 500000; i++) { auto e = pq.top(); pq.pop(); K[i] = e.first; pq.push(mp(e.first * e.second / (e.second + 1), e.second + 1)); } Int h; cin >> h; rep(i,h) { Int j; cin >> j; cout << K[j] << '\n'; } return 0; }