首页 > 其他 > 详细

CF983A Finite or not?(数学)

时间:2018-09-20 10:24:27      阅读:156      评论:0      收藏:0      [点我收藏+]

题意:给出分母,分子和进制,要求判断该数是否为有限小数。

Solution

表示并不知道怎么判断。

度娘:“一个分数在最简分数的情况下,如果它的分母只含有2和5两个质因数,这个分数就能化成有限小数.”。

感觉这个和进制有些关系,因为2和5恰好是进制10质因数分解后的结果。

那么问题变成了判断分母所含的质因数是否都为进制的质因数。

用辗转相处法求解。

注意最开始要讲分式化简(直接化简应该没有问题)。

Code

#include<iostream>
#include<cstdio>
using namespace std;
typedef long long ll;
ll p,q,b;
int n,flag;
ll gcd(ll a,ll b){return b?gcd(b,a%b):a;}
int main(){
    scanf("%d",&n);
    while(n--){
        scanf("%lld%lld%lld",&p,&q,&b);flag=1;
        q/=gcd(q,p);
        while(q!=1){
            ll x=gcd(q,b);
            q/=x;b=x;
            if(q!=1&&b==1){
                printf("Infinite\n");
                flag=0;
                break;
            }
        }
        if(flag)printf("Finite\n");
    }
    return 0;
}

 

CF983A Finite or not?(数学)

原文:https://www.cnblogs.com/ZH-comld/p/9678683.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!