首页 > 其他 > 详细

埃及分数(迭代深搜)

时间:2018-08-20 20:08:00      阅读:204      评论:0      收藏:0      [点我收藏+]
#include<bits/stdc++.h>
using namespace std;
long long ch,mo;
int dep;
long long ans[1000],s[1000];
int gcd(long long a,long long b)
{
    return b==0?a:gcd(b,a%b);
}
void outp()
{
    if(ans[dep]>s[dep])
    {
        for(int i=1;i<=dep;i++) ans[i]=s[i];
    }
}
void dfs(long long zi,long long mu,int d)
{
    long long a,b,w;
    if(d==dep)
    {
        s[d]=mu;
        if((zi==1)&&s[d]>s[d-1]) outp();
        return;
    }
    for(int i=max(s[d-1]+1,mu/zi+1);i<(dep-d+1)*mu/zi;i++)//此步骤着重理解,
    {                                            // 由上一步和dep深度决定i的取值范围 
        b=mu*i/gcd(mu,i);
        a=b*zi/mu-b/i;
        w=gcd(a,b);
        a/=w;b/=w;
        s[d]=i;
        dfs(a,b,d+1);
    }
}
int main(){
    scanf("%lld%lld",&ch,&mo);
    int i=gcd(ch,mo);
    ch/=i;
    mo/=i;
    for(dep=2;;dep++)
    {
        ans[1]=0;
        s[0]=0;
        ans[dep]=200000000;
        dfs(ch,mo,1);
        if(ans[1]!=0) break;
    }
    for(int j=1;j<=dep;j++)
    {
        printf("%d ",ans[j]);
    }
    return 0;
}

 

埃及分数(迭代深搜)

原文:https://www.cnblogs.com/719666a/p/9507714.html

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