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

心如止水
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>
            午夜精品久久久久久久男人的天堂| 欧美xx视频| 久久国产婷婷国产香蕉| 亚洲视频一二三| 99精品国产在热久久婷婷| 亚洲开发第一视频在线播放| 91久久国产综合久久| 亚洲麻豆av| 午夜精品久久久久久久男人的天堂 | 欧美日本一区二区三区 | 欧美日韩国产综合视频在线观看中文| 欧美日韩mv| 国产欧美日韩在线观看| 在线日韩电影| 在线综合+亚洲+欧美中文字幕| 一区二区久久久久久| 欧美亚洲三区| 欧美成人免费观看| 一区二区av在线| 久久精品中文字幕一区二区三区| 久久伊人精品天天| 国产精品第一区| 136国产福利精品导航| 亚洲天堂黄色| 欧美黄色一级视频| 亚洲一区在线免费| 久久综合久久久| 国产精品久久久久久久久搜平片| 精品成人一区二区三区| 亚洲字幕一区二区| 欧美激情按摩在线| 午夜国产精品视频| 欧美日韩免费视频| 亚洲国产天堂久久综合网| 亚洲综合成人婷婷小说| 欧美高清不卡在线| 久久国产精品99精品国产| 牛牛精品成人免费视频| 日韩一级免费| 免费成人性网站| 国产一区二区三区四区在线观看 | 国产日韩欧美a| 亚洲老司机av| 蜜桃久久av| 亚洲专区欧美专区| 欧美三级电影网| 亚洲美洲欧洲综合国产一区| 可以看av的网站久久看| 亚洲视频久久| 亚洲国产高清一区| 校园春色综合网| 国产精品久久国产愉拍| 99riav国产精品| 欧美激情一区二区三区全黄| 久久国产福利| 国产一区视频观看| 久久免费高清| 欧美在线91| 国产日韩在线播放| 亚洲另类一区二区| 欧美成人一区二区在线| 在线成人小视频| 国产精品久久夜| 亚洲午夜久久久| 99爱精品视频| 国产精品二区影院| 亚洲欧美综合国产精品一区| 一本大道久久精品懂色aⅴ| 欧美精品www| 一本久久青青| 99视频精品| 国产精品丝袜91| 久久久精品一区二区三区| 欧美伊人久久久久久午夜久久久久 | 1024国产精品| 欧美二区不卡| 欧美激情第二页| 一区二区三区高清在线| 99re成人精品视频| 国产精品久久福利| 久久精品亚洲国产奇米99| 久久米奇亚洲| 亚洲人成网站色ww在线 | 欧美一二三视频| 狠狠色狠狠色综合日日91app| 看片网站欧美日韩| 欧美大片在线观看| 亚洲午夜精品久久久久久浪潮| 亚洲午夜三级在线| 国产自产2019最新不卡| 亚洲高清不卡在线| 欧美日韩精品在线视频| 久久精品国产免费| 免费成人美女女| 午夜视频一区在线观看| 久久久噜噜噜久久中文字幕色伊伊| 亚洲国产一二三| 亚洲视频在线看| 亚洲成人在线网站| 亚洲午夜免费视频| 亚洲日韩欧美视频一区| 一区二区三区视频在线| 国内一区二区三区| 日韩视频―中文字幕| 国内精品久久久久久久果冻传媒| 欧美日韩国产成人在线91| 国产精品福利网| 久久一二三四| 欧美午夜视频在线| 欧美成人精精品一区二区频| 国产精品久久久久久久久久尿 | 99国产精品| 久久天天躁狠狠躁夜夜av| 亚洲深夜影院| 免费欧美高清视频| 久久精品国产亚洲精品| 欧美日韩的一区二区| 久久这里只精品最新地址| 欧美日韩亚洲91| 欧美激情一二三区| 精品999日本| 亚洲一区欧美| 亚洲午夜一二三区视频| 欧美成人免费全部观看天天性色| 久久激情综合网| 欧美午夜宅男影院| 亚洲欧洲日产国产网站| 伊人久久综合97精品| 欧美一区成人| 久久gogo国模啪啪人体图| 欧美日一区二区在线观看| 亚洲福利视频二区| 亚洲国产三级在线| 久久亚洲国产精品一区二区| 久久久久成人精品| 国产一区二区欧美| 性欧美大战久久久久久久久| 亚洲欧美视频在线观看| 国产精品久久久久99| 亚洲一二三四久久| 欧美一区网站| 国产午夜精品全部视频在线播放| 中文亚洲免费| 午夜在线视频一区二区区别| 欧美午夜电影完整版| 亚洲私人影吧| 欧美一区二区三区四区在线观看地址 | 亚洲欧美日韩在线综合| 欧美一进一出视频| 国产日韩av一区二区| 午夜久久黄色| 久久一区二区三区超碰国产精品| 国产主播一区| 免费人成精品欧美精品| 亚洲韩国精品一区| 亚洲图片在线| 国产精品你懂得| 欧美呦呦网站| 欧美成人精品高清在线播放| 亚洲国产一二三| 欧美日韩在线视频一区二区| 亚洲午夜91| 老司机一区二区三区| 91久久精品一区二区别| 亚洲一区中文| 国产日韩一区欧美| 久久久久久电影| 亚洲国产专区校园欧美| 亚洲一区二区视频| 国产欧美精品日韩精品| 久久一区视频| 日韩一级精品| 久久久精品一区二区三区| 亚洲欧洲精品一区二区三区| 欧美午夜在线一二页| 欧美在线一区二区三区| 亚洲三级色网| 久久久中精品2020中文| 亚洲免费av片| 国产日韩一区二区| 欧美日韩成人综合在线一区二区| 先锋a资源在线看亚洲| 亚洲国内欧美| 久久综合色天天久久综合图片| 制服丝袜亚洲播放| 在线播放日韩欧美| 国产精品一卡二卡| 欧美精品久久久久a| 久久av资源网| 中文国产一区| 91久久综合| 久久婷婷一区| 亚洲综合色丁香婷婷六月图片| 91久久久亚洲精品| 国产亚洲精品激情久久| 欧美性事在线| 欧美日韩少妇| 欧美激情精品久久久六区热门| 久久久91精品国产一区二区三区| 亚洲视频中文|