Expired License

Expired License


Expired License

这道题交给队友敲得,但是调试了一下午关于浮点数的精度老是出问题,参考了大佬的代码,终于知道怎么回事了

#include <iostream>
using namespace std;
typedef long long ll;
ll gcd(ll a, ll b)
{
    return b == 0 ? a : gcd(b, a % b);
}
bool check(ll n)
{
    if(n == 1) return false;
    for(ll i = 2; i <= n / i; i++)
        if(n % i == 0)
            return false;
    return true;
}
int main()
{
    double a, b;
    int t;
    cin >> t;
    while(t--)
    {
        cin >> a >> b;
        if(a == b) cout << 2 << ' ' << 2 << endl;
        else
        {
            long long int n = (ll)(a * 100000.0 + 0.5), m = (ll)(b * 100000.0 + 0.5);//要加0.5,否则精度会丢失
            cout << n << ' ' << m << endl;
            ll e = gcd(n, m);
            if(check(n / e) && check(m / e))
                cout << n / e << ' ' << m / e << endl;
            else
                cout << "impossible\n";
        }
    }
    return 0;
}
posted @   Flying_bullet  阅读(26)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· winform 绘制太阳,地球,月球 运作规律
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· AI与.NET技术实操系列(五):向量存储与相似性搜索在 .NET 中的实现
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 超详细:普通电脑也行Windows部署deepseek R1训练数据并当服务器共享给他人
点击右上角即可分享
微信分享提示