Codeforces Round 895 (Div. 3) C. Non-coprime Split

  1. 找到数字 x x x的因子 k k k,构造出 k , x − k k,x-k k,x−k即可。 因为 x = C 1 ∗ k x = C_1 * k x=C1∗k , x − k = ( C 1 − 1 ) ∗ k x - k = (C_1 - 1) * k x−k=(C1−1)∗k,保证其最小公因数不为 1 1 1
  2. 如果没有因子,即这个数字是质数,其不满足条件,证明如下:
    假设 A , B A,B A,B存在满足如下条件
    1. A + B = x 1. A + B = x 1.A+B=x
    2. G C D ( A , B ) = k ( k > 1 ) 2. GCD(A, B) = k (k >1) 2.GCD(A,B)=k(k>1)
      那么一定有
      A = C 1 ∗ k , B = C 2 ∗ k A = C_1 * k,B=C_2*k A=C1∗k,B=C2∗k
      A + B = k ( C 1 + C 2 ) = x A+B = k(C_1 + C_2) = x A+B=k(C1+C2)=x
      由反证法得到,这种情况存在时,x不是质数。
cpp 复制代码
#include <bits/stdc++.h>
using namespace std;

int gcd(int a, int b)
{
    return b ? gcd(b, a % b) : a;
}
void solve()
{
    int a, b;
    cin >> a >> b;
    int i = b;
    while (i > a)
    {
        if (i % 2 == 0)
            break;
        i--;
    }
    if (i == 2)
        cout << -1 << "\n";
    else
    {
        for (int j = 2; j * j <= i; j++)
        {
            if (i % j == 0)
            {
                cout << j << " " << i - j << "\n";
                return;
            }
        }
        cout << -1 << "\n";
    }
}
int main()
{

    ios::sync_with_stdio(false);
    cin.tie(0);
    int t;
    cin >> t;
    while (t--)
    {
        solve();
    }
}
相关推荐
奔跑吧邓邓子6 小时前
【C语言实战(59)】C语言打造你的专属密码管家
c语言·开发实战·密码管家
CoookeCola6 小时前
开源图像与视频过曝检测工具:HSV色彩空间分析与时序平滑处理技术详解
人工智能·深度学习·算法·目标检测·计算机视觉·开源·音视频
DARLING Zero two♡7 小时前
【优选算法】D&C-Mergesort-Harmonies:分治-归并的算法之谐
java·数据结构·c++·算法·leetcode
CoovallyAIHub7 小时前
万字详解:多目标跟踪(MOT)终极指南
深度学习·算法·计算机视觉
胡萝卜3.07 小时前
C++面向对象继承全面解析:不能被继承的类、多继承、菱形虚拟继承与设计模式实践
开发语言·c++·人工智能·stl·继承·菱形继承·组合vs继承
蜗牛沐雨7 小时前
解决 OpenSSL 3.6.0 在 macOS 上 Conan 构建失败的链接错误
c++·macos
wudl55667 小时前
Apache Flink Keyed State 详解之一
算法·flink·apache
CoovallyAIHub7 小时前
Arm重磅加码边缘AI!Flexible Access开放v9平台,实现高端算力普惠
深度学习·算法·计算机视觉
louisdlee.7 小时前
树状数组维护DP——前缀最大值
数据结构·c++·算法·dp
Python私教8 小时前
C 语言进制转换全景指南
c语言·开发语言·arm开发