zoukankan      html  css  js  c++  java
  • Benefit UVA

    首先对于C不能整除A的状况肯定排除

    然后得到B=C/A

    然后取G=GCD(A,B)

    如果G==1,那么此时B就是解

    否则的话,就证明A,B,的最小公倍数肯定不是C,因为其最小公倍数是A*B/G

    那么我们就去掉这个公因子,方法是A/G,B*G

    即可消去两者公共的倍数,同时还可以保证A*B是一个定值

    循环直到G==1为止。。。是。。。是。。是。。。挺神奇的。。。

    题意借鉴自https://blog.csdn.net/libin56842/article/details/46442083

    https://blog.csdn.net/just_sort/article/details/50983350

    #include <iostream>
    #include <cstdio>
    #include <cstring>
    #include <algorithm>
    #include <queue>
    #include <vector>
    #include <cmath>
    #define mem(a, b) memset(a, b, sizeof(a))
    using namespace std;
    const int maxn = 10010, INF = 0x7fffffff;
    typedef long long LL;
    
    int gcd(int a, int b)
    {
        return b==0?a:gcd(b, a%b);
    }
    
    
    int main()
    {
        int T;
        cin>> T;
        while(T--)
        {
            int a, b, c;
            cin>> a >> c;
            if(c % a != 0)
                cout<< "NO SOLUTION" <<endl;
            else
            {
                b = c / a;
                if(gcd(a, b) == 1)
                    cout<< b <<endl;
                else
                {
                    while(gcd(a, b) != 1)
                    {
                        int temp = gcd(a, b);
                        a /= temp;
                        b *= temp;
                    }
                    cout<< b <<endl;
                }
            }
    
        }
    
        return 0;
    }
    自己选择的路,跪着也要走完。朋友们,虽然这个世界日益浮躁起来,只要能够为了当时纯粹的梦想和感动坚持努力下去,不管其它人怎么样,我们也能够保持自己的本色走下去。
  • 相关阅读:
    类加载
    LinkedList插入排序实现
    99乘法表
    关于IO流的抽象类
    分解质因数
    Struts2小demo遇到的几个问题
    Tomcat设置欢迎页问题
    数据库迁移
    EF – 1.模式
    正则表达式
  • 原文地址:https://www.cnblogs.com/WTSRUVF/p/9316412.html
Copyright © 2011-2022 走看看