码迷,mamicode.com
首页 > 其他好文 > 详细

埃及分数(迭代深搜)

时间:2018-08-20 20:12:35      阅读:1056      评论:0      收藏:0      [点我收藏+]

标签:bit   ace   mes   ++   code   dfs   深度   i++   决定   

#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;
}

 

埃及分数(迭代深搜)

标签:bit   ace   mes   ++   code   dfs   深度   i++   决定   

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

(0)
(2)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!