CFCF2169D2.Removal of a Sequence (Hard Version)
提高+/省选-
通过率:0%
AC君温馨提醒
该题目为【codeforces】题库的题目,您提交的代码将被提交至codeforces进行远程评测,并由ACGO抓取测评结果后进行展示。由于远程测评的测评机由其他平台提供,我们无法保证该服务的稳定性,若提交后无反应,请等待一段时间后再进行重试。
题目描述
这是该问题的困难版本。不同之处在于本版本对 x 的约束更大:x≤1012。
Polycarp 拥有一个从 1 到 1012 的所有自然数组成的序列。他决定对这个序列执行如下操作 x 次:
- 每次同时删除所有位于位置 y、2⋅y、3⋅y、……、m⋅y≤n 的数字,其中 n 是当前序列的长度。
之后,Polycarp 想要找到剩余序列中的第 k 个数,或判断最终序列长度是否小于 k。
请你帮助 Polycarp 解决这个问题!
例如,设 x=2,y=3,k=5,那么:

用红线划掉的数字表示第一次操作被删除的元素,用蓝线划掉的数字表示第二次操作后被删除的元素。因此,k=5 位置上的元素是 10。
输入格式
每个测试包含多个测试用例。第一行包含测试用例个数 t(1≤t≤10)。接下来是每个测试用例的描述。
每个测试用例仅一行,包含三个整数 x,y,k(1≤x,y,k≤1012)。
输出格式
每个测试用例输出一行,表示最终序列中第 k 个位置上的正整数。如果最终序列长度小于 k,则输出 −1。
输入输出样例
输入#1
6 2 3 5 2 5 1 20 2 1000000000000 175 10 28 1000000000 998244353 1999999999 1 1 1
输出#1
10 1 -1 2339030304 4672518823 -1