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

心如止水
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>
            欧美亚洲一级| 欧美在线关看| 亚洲人精品午夜在线观看| 性欧美激情精品| 欧美一区在线直播| 久久国产主播| 你懂的视频一区二区| 欧美成人激情在线| 亚洲精品综合精品自拍| 亚洲精品一区二区三区99| 99国内精品| 亚洲欧美www| 久久精品视频在线免费观看| 欧美成人激情在线| 欧美午夜性色大片在线观看| 国产日韩欧美高清免费| 亚洲第一精品夜夜躁人人躁| 99在线视频精品| 欧美一区二区视频97| 欧美大秀在线观看| 一区二区三欧美| 久久精品久久99精品久久| 久久综合久久综合这里只有精品| 欧美日本乱大交xxxxx| 国产欧美日韩| 日韩午夜电影在线观看| 久久av一区二区三区| 欧美二区乱c少妇| 亚洲午夜羞羞片| 欧美大片一区| 国产一区白浆| 亚洲一区二区黄| 欧美黄色成人网| 午夜久久久久久| 欧美韩日亚洲| 精品成人在线观看| 亚洲欧美成人| 亚洲日本欧美在线| 免费一级欧美片在线播放| 国产精品福利在线观看| 亚洲欧洲视频在线| 久久久久久久国产| 亚洲一区欧美| 欧美日韩精品不卡| 亚洲精品1区2区| 久久天堂av综合合色| 亚洲在线播放| 国产精品毛片a∨一区二区三区| 亚洲国产欧美一区二区三区同亚洲 | 久久久国产精品亚洲一区 | 国产午夜一区二区三区| 亚洲视频日本| 亚洲精品123区| 欧美1区2区视频| 亚洲精华国产欧美| 91久久香蕉国产日韩欧美9色 | 久久精品麻豆| 亚洲欧美国产高清va在线播| 欧美午夜精品一区二区三区| 一区二区三区 在线观看视频 | 欧美成人精品h版在线观看| 欧美一区二区三区四区在线观看| 国产精品免费电影| 午夜精品国产更新| 亚洲男人影院| 国产日韩欧美三区| 久久久免费av| 久久夜色精品国产欧美乱极品| 依依成人综合视频| 欧美二区在线看| 欧美黄色日本| 亚洲女女女同性video| 亚洲欧美春色| 在线成人小视频| 亚洲国产网站| 国产精品二区二区三区| 久久国产精品一区二区三区| 久久精品五月婷婷| 亚洲精品中文字幕在线| 99xxxx成人网| 国产日韩欧美二区| 亚洲国产经典视频| 欧美日韩在线播| 久久精品国产久精国产思思| 久久久国产精品一区二区中文| 亚洲国产日韩在线| 在线亚洲高清视频| 国产中文一区二区三区| 蜜桃av综合| 欧美日韩一区二区三区视频| 久久成人精品一区二区三区| 久久久午夜视频| 亚洲午夜精品网| 久久精品一区二区| 亚洲视频福利| 久久精品视频免费播放| 在线亚洲精品| 久久久久久成人| 亚洲一区二区精品在线| 久久久www免费人成黑人精品| 亚洲六月丁香色婷婷综合久久| 一区二区三区欧美成人| 在线播放中文字幕一区| 99视频精品在线| 亚洲第一天堂av| 小处雏高清一区二区三区| 亚洲精品一区二区三区婷婷月 | 欧美成人精品影院| 国产精品一区毛片| 亚洲国产视频一区二区| 红桃视频一区| 亚洲图片激情小说| 亚洲三级视频| 久久人人97超碰人人澡爱香蕉| 国产一级一区二区| 艳女tv在线观看国产一区| 亚洲电影免费观看高清| 午夜视频一区| 亚洲一区国产视频| 欧美 日韩 国产精品免费观看| 亚洲欧美色一区| 欧美午夜精品伦理| 亚洲第一在线综合网站| 国一区二区在线观看| 亚洲欧美视频| 小黄鸭精品密入口导航| 欧美视频在线一区| 亚洲毛片在线免费观看| 日韩视频不卡| 欧美1级日本1级| 欧美国产国产综合| 亚洲国产欧美久久| 免费在线成人| 亚洲国产高清一区二区三区| 亚洲国产精品一区二区尤物区| 久久成人国产精品| 久久亚洲电影| 1000精品久久久久久久久| 久久av一区二区三区| 久久久久久免费| 黄色免费成人| 老司机成人在线视频| 欧美成人r级一区二区三区| 在线观看福利一区| 欧美wwwwww| 亚洲精品一二区| 亚洲欧美视频在线观看| 国产日韩精品在线播放| 久久久久国内| 亚洲精品免费在线| 亚洲综合成人在线| 国产欧美一区在线| 久久影院午夜论| 亚洲经典一区| 午夜精品福利在线| 亚洲成人影音| 欧美三级午夜理伦三级中文幕| 一区二区欧美亚洲| 久久一区亚洲| 99v久久综合狠狠综合久久| 国产精品任我爽爆在线播放| 欧美伊人精品成人久久综合97| 暖暖成人免费视频| 制服丝袜激情欧洲亚洲| 国产亚洲欧美一区在线观看| 美女被久久久| 亚洲网站视频| 欧美成人亚洲成人| 亚洲欧美激情四射在线日| 激情久久综艺| 欧美午夜精品久久久久久超碰| 欧美一区日本一区韩国一区| 亚洲成色777777女色窝| 午夜精品一区二区三区电影天堂| 伊人成人在线| 国产欧美一级| 欧美日韩午夜| 久久午夜电影网| 亚洲欧洲99久久| 亚洲人成高清| 欧美成人性生活| 久久爱91午夜羞羞| 亚洲天堂免费在线观看视频| 伊人一区二区三区久久精品| 国产精品欧美久久| 欧美区高清在线| 久久人人97超碰国产公开结果 | 午夜精品www| 亚洲二区在线视频| 欧美在线日韩| 一区二区三区精品| 亚洲国产视频直播| 国产一级揄自揄精品视频| 欧美午夜视频在线观看| 欧美电影免费观看| 麻豆成人综合网| 久久精品一本| 久久久久久夜| 久久精品夜色噜噜亚洲aⅴ| 亚洲欧美成人精品|