import sys input = sys.stdin.readline import math L = [0]*60 #これをしないとTLE? for i in range(2,60): L[i] = math.ceil(pow(10,18) ** (1/i)) + 10 def main(): T = int(input()) for _ in range(T): k = int(input()) ng = 0 ok = pow(10,18) + 10 while abs(ok - ng) > 1: mid = (ok + ng) // 2 if check(mid) >= k: ok = mid else: ng = mid print(ok) def check(n): #n以下の累乗数の個数 cnt = [0]*60 #i乗と書けるものの個数。 for i in reversed(range(2,60)): #同じ値でもiが大きいほうでカウント。 #小さいほうでカウントする約数でみないといけない。 #大きいほうに寄せると、倍数でみることができる。 ok = 0 ng = L[i] while abs(ok - ng) > 1: mid = (ok+ng) // 2 if pow(mid,i) <= n: ok = mid else: ng = mid ok -= 1 #1を除く cnt[i] = ok - sum(cnt[::i]) #iの倍数は全て上でそこでカウントされている。 return sum(cnt) + 1 #除かれた1を足す if __name__ == "__main__": main()