青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

心如止水
Je n'ai pas le temps
posts - 400,comments - 130,trackbacks - 0

給出一個(gè)分?jǐn)?shù),比如19/45,把它寫成若干個(gè)形如1/Ri的分?jǐn)?shù)的和的形式,比如19/45=1/5+1/6+1/18,要求分母不能重復(fù)使用并且使用的分?jǐn)?shù)的個(gè)數(shù)最少。(如果有多組個(gè)數(shù)相同的解,最后的分?jǐn)?shù)的分母越小越好,這對于題目來說是次要的。)
1、分母從小到大搜索
為了避免重復(fù)搜索
2、使用迭代加深搜索
求“步驟數(shù)最少”這類問題,基本上有兩種似乎:廣搜、迭代加深搜索。對于這道題來說,如果廣搜將永遠(yuǎn)得不到結(jié)果,分母可以無限大!但是迭代加深搜索就比較好,雖然做了許多重復(fù)工作,但狀態(tài)空間至少被限制住了。如果當(dāng)前正在枚舉的分母,使得接下來的選擇即使每次都選擇最大,達(dá)到最大深度的時(shí)候也不可能達(dá)到目標(biāo)分?jǐn)?shù),那么當(dāng)前正在枚舉的分母及比它還大的分母,都不需要枚舉了。這樣可以給分母確定一個(gè)上界。另外,已經(jīng)得到的結(jié)果加上當(dāng)前枚舉的分母對應(yīng)的分?jǐn)?shù),要小于等于目標(biāo)分?jǐn)?shù),這樣給分母確定了一個(gè)下界(可以在O(1)的復(fù)雜度內(nèi)確定這個(gè)下界)。

在下面的代碼中,因?yàn)榇_定上下界都使用了浮點(diǎn)運(yùn)算,最終還是需要把當(dāng)前結(jié)果和目標(biāo)結(jié)果比較。
浮點(diǎn)運(yùn)算~真讓人糾結(jié)的東西!

以下是我的代碼:
#include<algorithm>
#include
<cstdio>
#include
<cmath>
using namespace std;

int gcd(int a,int b)
{
    
for(int t=a%b;t;a=b,b=t,t=a%b); return b;
}
struct Type
{
    Type():a_(
0),b_(1) {}
    Type(
int a,int b):a_(a),b_(b) {}

    
int a_,b_;
};
Type 
operator+(const Type &a,const Type &b)
{
    Type re(a.a_
*b.b_+a.b_*b.a_,a.b_*b.b_);
    
int t(gcd(re.a_,re.b_));
    re.a_
/=t;
    re.b_
/=t;
    
return re;
}
bool operator==(const Type &a,const Type &b)
{
    
return (a.a_*b.b_==b.a_*a.b_);
}

Type target;
int ans,r[10000],t[10000];
bool found;

void dfs(const int &depth,const int &last,const Type &now)
{
    
if(depth>ans)
    {
        
if(now==target)
        {
            
if(found)
            {
                
bool cover(false);
                
for(int i=ans;i>=1;i--)
                    
if(r[i]>t[i])
                    {
                        cover
=true;
                        
break;
                    }
                    
else if(r[i]<t[i])
                        
break;
                
if(cover)
                    
for(int i=1;i<=ans;i++)
                        r[i]
=t[i];
            }
            
else
            {
                
for(int i=1;i<=ans;i++)
                    r[i]
=t[i];
                found
=true;
            }
        }
        
return;
    }
    
for(int i=max(last+1,(int)ceil((double)(target.b_*now.b_)/(target.a_*now.b_-target.b_*now.a_))); ;i++)
    {
        Type news(now
+Type(1,i));
        
if(depth+(int)ceil((double)(target.a_*news.b_-target.b_*news.a_)*(i+1)/(target.b_*news.b_))>ans)
            
break;
        t[depth]
=i;
        dfs(depth
+1,i,news);
    }
}

int main()
{
    freopen(
"data.in","r",stdin);
    freopen(
"data.out","w",stdout);

    
while(scanf("%d%d",&target.a_,&target.b_)==2)
    {
        found
=false;
        
for(ans=1; ;ans++)
        {
            dfs(
1,0,Type());
            
if(found)
                
break;
        }

        
for(int i=1;i<=ans;i++)
        {
            
if(i!=1)
                printf(
" ");
            printf(
"%d",r[i]);
        }
        printf(
"\n");
    }

    
return 0;
}
posted on 2011-05-09 22:59 lee1r 閱讀(2447) 評論(1)  編輯 收藏 引用 所屬分類: 題目分類:搜索

FeedBack:
# re: 經(jīng)典迭代加深搜索——埃及分?jǐn)?shù)
2014-06-09 17:57 | lyd
剛剛看了看你的這個(gè)問題的代碼,發(fā)現(xiàn)有個(gè)問題,但是在我的代碼中也有相同的問題,無法解決希望我們可以探討一下,有興趣可以訪問我的網(wǎng)易博客:http://lydws.blog.163.com/。就是有一組數(shù)據(jù):3 997;這組數(shù)據(jù)我們的答案都是:354 5982 58823;我對比了很多人的代碼,也都是這個(gè)問題,正確答案其實(shí)不是這個(gè),不過我這里沒有那個(gè)正確答案,我先找找看有沒有,如果不麻煩的話你可以看一看,謝謝。  回復(fù)  更多評論
  
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            久久一区二区三区国产精品| 久久免费高清视频| 亚洲午夜精品福利| 亚洲免费在线观看视频| 亚洲午夜激情网页| 亚洲午夜精品一区二区| 性18欧美另类| 中文一区二区| 91久久精品国产91性色| 亚洲国产成人91精品| 亚洲日韩第九十九页| 99精品欧美一区| 欧美一区二区在线视频| 麻豆九一精品爱看视频在线观看免费| 136国产福利精品导航| 亚洲成人在线视频播放| 9l视频自拍蝌蚪9l视频成人| 亚洲欧美精品一区| 久久综合久久美利坚合众国| 亚洲精品国精品久久99热一| 亚洲已满18点击进入久久| 久久久噜噜噜久久狠狠50岁| 欧美日韩调教| 激情五月***国产精品| 日韩视频在线播放| 久久久久久久一区二区三区| 亚洲乱码国产乱码精品精| 久久精品亚洲一区二区三区浴池| 欧美大片免费观看| 一区免费观看视频| 亚洲欧美激情四射在线日| 欧美国产激情| 欧美一级视频免费在线观看| 欧美精品久久久久a| 狠狠色狠狠色综合人人| 午夜精品久久久| 91久久在线播放| 久久精品中文字幕一区| 另类尿喷潮videofree| 久久都是精品| 久久精品国产v日韩v亚洲 | 日韩视频一区二区在线观看 | 性做久久久久久久免费看| 欧美成在线视频| 欧美一区不卡| 国产精品乱人伦一区二区| 亚洲风情亚aⅴ在线发布| 久久久精品国产99久久精品芒果| 一区二区三区日韩精品| 欧美精品一级| 亚洲狼人精品一区二区三区| 欧美激情91| 美女国内精品自产拍在线播放| 国产亚洲激情视频在线| 亚洲欧美日韩国产综合在线| av不卡在线看| 欧美午夜精品理论片a级按摩 | 欧美国产日韩一区二区在线观看| 噜噜噜噜噜久久久久久91| 亚洲精品一区在线观看| 亚洲视频日本| 欧美精品午夜| 99日韩精品| 最近看过的日韩成人| 美女999久久久精品视频| 亚洲国产婷婷香蕉久久久久久| 久久久久综合网| 欧美中文字幕久久| 伊人久久婷婷| 亚洲缚视频在线观看| 欧美成人精品1314www| 亚洲黄色影片| 亚洲精品久久久久久久久久久| 欧美精品一区二区三区久久久竹菊 | 在线日韩av片| 亚洲国产精品一区二区三区| 欧美日韩成人一区二区三区| 99re视频这里只有精品| 一区二区三区四区精品| 国产美女扒开尿口久久久| 久久激情网站| 久久午夜电影网| 99re热这里只有精品视频| 亚洲影院一区| 伊人婷婷欧美激情| 亚洲精品乱码| 国产在线一区二区三区四区| 国产精品爽黄69| 午夜欧美不卡精品aaaaa| 午夜在线观看免费一区| 在线播放中文一区| 亚洲免费久久| 国产一区二区丝袜高跟鞋图片| 麻豆国产精品777777在线| 欧美精品三级在线观看| 欧美在线在线| 欧美激情网友自拍| 欧美在线啊v| 欧美国产视频在线| 久久九九久精品国产免费直播| 牛夜精品久久久久久久99黑人| 午夜精品久久久久久久白皮肤| 久久九九国产| 亚洲欧美电影在线观看| 免费不卡在线观看| 久久久国产一区二区| 欧美日韩免费高清一区色橹橹| 久久综合网色—综合色88| 欧美特黄a级高清免费大片a级| 欧美成人日韩| 狠狠色综合色区| 亚洲自拍偷拍麻豆| 亚洲天堂久久| 欧美精品成人一区二区在线观看| 久久久久久久波多野高潮日日| 欧美色偷偷大香| 亚洲肉体裸体xxxx137| 亚洲第一狼人社区| 久久精彩免费视频| 午夜精品久久久久久久久久久久| 欧美高清在线一区二区| 欧美99久久| 精品盗摄一区二区三区| 亚洲一区欧美激情| 99re热精品| 欧美日韩成人综合在线一区二区| 欧美大片在线看免费观看| 国产一本一道久久香蕉| 亚洲视频在线观看视频| 一区二区三区成人精品| 欧美精品成人91久久久久久久| 亚洲国产片色| 亚洲欧洲在线播放| 欧美国产激情| 91久久综合亚洲鲁鲁五月天| 亚洲精品久久久一区二区三区| 蜜桃久久精品一区二区| 欧美二区视频| 亚洲理论在线| 欧美日韩综合网| 亚洲一二三区精品| 欧美中文字幕在线| 国语自产精品视频在线看| 久久精品国内一区二区三区| 久久资源av| 激情综合自拍| 欧美国产精品专区| 99精品视频一区| 欧美一区二区三区免费视频| 国产精品日韩欧美一区| 久久精品国产2020观看福利| 欧美jizz19性欧美| 999亚洲国产精| 国产精品高潮在线| 欧美激情精品久久久久久黑人| 亚洲国产日韩欧美在线图片| 欧美电影在线观看| 欧美xart系列高清| 午夜精品视频在线观看| 久久午夜电影网| 久久手机免费观看| 最新日韩在线视频| 亚洲人成亚洲人成在线观看| 欧美超级免费视 在线| 在线亚洲自拍| 久久成人精品电影| 亚洲精品在线观| 亚洲一区二区影院| 黄色影院成人| 亚洲精品一二三| 国产精品美女久久久久久2018| 久久国产精品网站| 欧美xx视频| 欧美专区在线观看| 欧美国产91| 在线日韩日本国产亚洲| 欧美韩国日本综合| 久久国产免费看| 久久综合色播五月| 亚洲国产精品一区二区尤物区| 欧美人牲a欧美精品| 欧美一区2区三区4区公司二百| 亚洲激情网站免费观看| 久久成人一区| 亚洲性感激情| 亚洲国产黄色片| 国产欧美日韩在线视频| 欧美精品色综合| 久久久亚洲精品一区二区三区| 中文一区字幕| 亚洲精品久久久久久久久| 免费亚洲一区| 久久精品一本| 亚洲欧美电影在线观看| 亚洲精品一区久久久久久| 激情小说亚洲一区| 国产一区二区三区在线观看精品| 欧美性猛交xxxx免费看久久久| 欧美电影免费观看| 久久只有精品|