ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

埃及分数(迭代搜索(按层数剪枝))

2021-09-04 15:35:07  阅读:214  来源: 互联网

标签:剪枝 迭代 dep LL limt xx 层数 way best



//在古埃及,人们使用单位分数的和(形如1/a的, a是自然数)表示一切有理数 
//x/y=1/a+1/b+....+1/x+1/y+1/z+....
#include<stdio.h>
#include<algorithm>
using namespace std;
typedef long long LL;
const int N=1e5+5;
const int INF=0x3f3f3f3f;
bool flag;
LL best,limt;
LL way[N],ans[N];//way:临时数组 
void dfs(LL x , LL y , LL dep)
{
    LL l1,l2,xx,yy;
    //当前分母必须比上次的分母大 
    l1 = max(way[dep-1]+1,y/x); //寻找当前层数分母的最小值 
    //至少为:(1/i)*(limt-dep+1)>=a/b
    l2 = min(y*(limt-dep+1)/x,best-1);//寻找当前层数分母的最大值 
    for(LL i=l1;i<=l2;i++)
    {//x/y=1/i+....<---->....=x/y-1/i=(x*i-y)/(y*i)
        xx=x,yy=y,way[dep]=i;
        xx=xx*i-yy;//计算剩余的分子 
        if(xx<0) continue;
        yy=yy*i;//计算剩余的分母 
        if(dep<limt) dfs(xx,yy,dep+1);
        if(i<best&&xx==0)//dep==limt--xx=0说明limt个数累加等于a/b 
        {
            flag=true,best=i;
            for(int j=1;j<=limt;j++)
				ans[j]=way[j]; //更新答案
        }
    } 
}
int main()
{
    LL a,b;
    scanf("%lld %lld",&a,&b);
    flag=false,way[0]=1,best=INF;
    while(!flag){
        limt++; // 枚举当前深搜的层数 
        dfs(a,b,1);
    }
    printf("%d/%d = ",a,b);
    for(LL i = 1; i < limt ; i ++)
    	printf("1/%d + ",ans[i]);
    printf("1/%d",ans[limt]);
    
    return 0; 
}

标签:剪枝,迭代,dep,LL,limt,xx,层数,way,best
来源: https://blog.csdn.net/weixin_45410154/article/details/120100576

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有