CFCF2169D2.Removal of a Sequence (Hard Version)

提高+/省选-

通过率:0%

AC君温馨提醒

该题目为【codeforces】题库的题目,您提交的代码将被提交至codeforces进行远程评测,并由ACGO抓取测评结果后进行展示。由于远程测评的测评机由其他平台提供,我们无法保证该服务的稳定性,若提交后无反应,请等待一段时间后再进行重试。

题目描述

这是该问题的困难版本。不同之处在于本版本对 xx 的约束更大:x1012x \le 10^{12}

Polycarp 拥有一个从 11101210^{12} 的所有自然数组成的序列。他决定对这个序列执行如下操作 xx 次:

  • 每次同时删除所有位于位置 yy2y2 \cdot y3y3 \cdot y、……、mynm \cdot y \le n 的数字,其中 nn 是当前序列的长度。

之后,Polycarp 想要找到剩余序列中的第 kk 个数,或判断最终序列长度是否小于 kk

请你帮助 Polycarp 解决这个问题!

例如,设 x=2x = 2y=3y = 3k=5k = 5,那么:


用红线划掉的数字表示第一次操作被删除的元素,用蓝线划掉的数字表示第二次操作后被删除的元素。因此,k=5k = 5 位置上的元素是 1010

输入格式

每个测试包含多个测试用例。第一行包含测试用例个数 tt1t101 \le t \le 10)。接下来是每个测试用例的描述。

每个测试用例仅一行,包含三个整数 x,y,kx, y, k1x,y,k10121 \le x, y, k \le 10^{12})。

输出格式

每个测试用例输出一行,表示最终序列中第 kk 个位置上的正整数。如果最终序列长度小于 kk,则输出 1-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
首页