1 条题解

  • 0
    @ 2026-5-4 12:35:58

    解题思路

    假设我们已经选定了答案中的 xxyy,且 xx 不是 yy 的约数。由于 LCM(x,y)\operatorname{LCM}(x, y) 落在 [l,r][l, r] 区间内,我们可以选择 xxLCM(x,y)\operatorname{LCM}(x, y) 作为答案。因此,如果答案存在,那么也一定存在一个满足 xxyy 的约数的答案。

    如果 2l>r2l > r,则不存在满足 lx<yrl \le x < y \le rxyx \mid y 的数对 (x,y)(x, y)。否则,x=lx = ly=2ly = 2l 就是一个可行的答案。


    代码实现

    #include <bits/stdc++.h>
    using namespace std;
    
    int main() {
        ios::sync_with_stdio(false);
        cin.tie(nullptr);
    
        int t;
        cin >> t;
        while (t--) {
            long long l, r;
            cin >> l >> r;
            if (l * 2 > r) {
                cout << "-1 -1\n";
            } else {
                cout << l << ' ' << l * 2 << '\n';
            }
        }
        return 0;
    }
    • 1

    信息

    ID
    6781
    时间
    1000ms
    内存
    256MiB
    难度
    10
    标签
    递交数
    1
    已通过
    1
    上传者