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

The Fourth Dimension Space

枯葉北風(fēng)寒,忽然年以殘,念往昔,語默心酸。二十光陰無一物,韶光賤,寐難安; 不畏形影單,道途阻且慢,哪曲折,如渡飛湍。斬浪劈波酬壯志,同把酒,共言歡! -如夢令

POJ 1095 卡特蘭數(shù)+dfs

感覺和上次codeforce的第四題有點(diǎn)像,雖然沒做出來,呵呵。
看來枚舉左右子樹這一招還是蠻常用的。其實(shí)我本來想練下卡特蘭數(shù)的,結(jié)果變成練DFS了。
注意遞歸求解左右孩子時(shí)的那兩個(gè)參數(shù),一定要先加上1,否則就不對了。

#include<stdio.h>
long long a[20];  
long long b[20]; 
//定理:n個(gè)結(jié)點(diǎn)能形成的二叉樹總數(shù)為 卡特蘭數(shù) C(2n,n)/(n+1) 或者由遞推公式Ci+1=2*(2*i+1)/(i+2)*Ci 
//設(shè)計(jì)figure(n),n代表這棵樹整體的偏移量
//分別算出其左右子樹各自的偏移量,遞歸求解即可
//由于先遞歸左兒子,輸出順序與題意相符
void figure(int n) 
{       
    
int t,i,j;  
    
if(n==1){printf("X");return;}     
    j
=0;
    
while(trueif(b[++j]>=n) break;         
    n
=n-b[j-1];//j代表有幾個(gè)結(jié)點(diǎn),n此時(shí)代表在這些結(jié)點(diǎn)下的序號    
    for(i=0;i<j;i++)   
    
{          
        t
=a[i]*a[j-1-i];    
        
if(t>=n)  break;           
        
else n=n-t;   
    }
     
    
if(i!=0)    //i是此時(shí)左子樹掛的節(jié)點(diǎn)數(shù)
    {        
        printf(
"(");  
        figure(b[i
-1]+1+(n-1)/a[j-1-i]);//初始的時(shí)刻,只需要增加1,左子樹的偏移量就增加1,而之后的部分,需要右子樹變換a[j-i-1]次,左子樹的偏移量才增加1  
        printf(")");
    }
    
    printf(
"X");  
    
if(i!=j-1)    
    
{        
        printf(
"(");  
        figure(b[j
-2-i]+1+(n-1)%a[j-1-i]);   
        printf(
")");   
    }
   
}
        
int main()  
{      
    
int n;   
    
int i,j;     
    a[
0]=1;     
    a[
1]=1;       
    b[
1]=1;     
    b[
0]=0;     
    
for(i=2;i<20;i++
    
{        
        a[i]
=2*(2*(i-1)+1)*a[i-1]/(i+1) ;//卡特蘭數(shù)遞推公式
        b[i]=b[i-1]+a[i];   
    }
    
    
while(scanf("%d",&n)&&n)   
    
{      
        solve(n);   
        printf(
"\n");   
    }
       
    
return 0;  
}
  

posted on 2010-04-13 17:33 abilitytao 閱讀(2165) 評論(5)  編輯 收藏 引用

評論

# re: POJ 1095 卡特蘭數(shù)+dfs 2010-04-13 19:37 abilitytao

srand(time(NULL))
是以當(dāng)前到1970年的時(shí)間間隔的秒數(shù)為種子,time(NULL),指不需要保存一個(gè)時(shí)間對象
通常情況下可以Time tTime;然后time(&tTime)來將這個(gè)時(shí)間獲取到。

而rand()是以剛才生成的種子為基礎(chǔ)來產(chǎn)生一個(gè)隨機(jī)數(shù),每調(diào)用一次產(chǎn)生一個(gè)數(shù),貌似如果期間沒有再次調(diào)用srand來生成種子,rand()是接著前面的序列來產(chǎn)生下一個(gè)數(shù)。(個(gè)人想法)
因?yàn)椋?
srand(time(NULL));
int x = rand();
int y = rand();
x和y的值不一樣。而:
srand(time(NULL));
int x = rand();
srand(time(NULL));
int y = rand();
則是相同,因?yàn)楹笠环N使用了同一個(gè)種子(運(yùn)行期間時(shí)間很短,返回的秒數(shù)相同)  回復(fù)  更多評論   

# re: POJ 1095 卡特蘭數(shù)+dfs[未登錄] 2010-04-16 09:49 yoyo

I can understand a[i] stores catalan number when there are i nodes.
but what is b[] used for?

Thanks,
yoyo  回復(fù)  更多評論   

# re: POJ 1095 卡特蘭數(shù)+dfs[未登錄] 2010-04-16 10:59 abilitytao

@yoyo
b[i]=a[1]+a[2]+...a[i];  回復(fù)  更多評論   

# re: POJ 1095 卡特蘭數(shù)+dfs[未登錄] 2010-04-16 11:19 yoyo

@abilitytao
:-) I can know it from code, while no idea what's the purpose of b[i] = a[1]+...a[i]

Thanks for quick replying.

yoyo  回復(fù)  更多評論   

# re: POJ 1095 卡特蘭數(shù)+dfs 2010-04-16 17:50 abilitytao

@yoyo
the intention is to find the node number of the the tree that you want.
you are not chinese? or you can understand it through my notes by Chinese.  回復(fù)  更多評論   


只有注冊用戶登錄后才能發(fā)表評論。
網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            亚洲人成网站777色婷婷| 亚洲欧美另类中文字幕| 欧美尤物一区| 亚洲综合精品| 国产精品毛片大码女人| 亚洲在线视频免费观看| 一本久道综合久久精品| 欧美日韩国产三区| 亚洲影院污污.| 午夜精彩国产免费不卡不顿大片| 国产精品视频一二三| 欧美在线亚洲一区| 久久久国产午夜精品| 亚洲第一成人在线| 亚洲精品一区在线观看香蕉| 欧美三级黄美女| 久久精品国产77777蜜臀| 久久免费视频这里只有精品| 亚洲精品在线免费| 一区二区三区国产| 一区免费观看| 亚洲伦伦在线| 国产专区欧美精品| 亚洲欧洲日夜超级视频| 国产精品看片资源| 免费亚洲一区二区| 欧美四级在线| 欧美91视频| 国产精品普通话对白| 美女网站久久| 国产精品高潮呻吟久久av无限 | 国产日本欧美一区二区三区| 久久一本综合频道| 欧美日韩99| 久久这里只有精品视频首页| 欧美另类99xxxxx| 久久久一区二区三区| 欧美日韩高清在线一区| 久久婷婷蜜乳一本欲蜜臀| 欧美激情一区二区三区| 久久久久久高潮国产精品视| 欧美日本亚洲| 欧美大片一区| 国产一区二区三区网站| 亚洲美女中文字幕| 亚洲国产片色| 久久精品国产v日韩v亚洲| 一区二区精品国产| 免费不卡在线观看av| 久久久久网址| 国产精品少妇自拍| 一个人看的www久久| 亚洲精品国产系列| 久久精品成人一区二区三区蜜臀| 亚洲综合精品| 欧美日韩一级黄| 亚洲激情在线视频| 在线观看精品视频| 欧美一区二视频| 午夜精品视频在线观看| 欧美日韩国产大片| 亚洲国语精品自产拍在线观看| 尤物网精品视频| 久久精品国产视频| 久久免费视频在线观看| 国产午夜精品一区二区三区视频| 亚洲一级特黄| 亚洲欧美日韩精品久久久久| 欧美日韩在线大尺度| 亚洲精品久久久久久久久久久| 亚洲激情视频在线| 美女视频黄a大片欧美| 欧美成熟视频| 亚洲激情不卡| 欧美国产日韩一区| 亚洲人妖在线| 亚洲无线视频| 国产精品一区二区三区免费观看| 亚洲午夜伦理| 欧美在线观看天堂一区二区三区| 国产欧美日本| 久久久午夜电影| 亚洲国产精品一区二区第一页| 亚洲三级网站| 欧美日韩视频| 亚洲欧美日韩一区在线| 久久久久一区二区| 亚洲国产一区二区精品专区| 欧美激情小视频| 一区二区三区精密机械公司| 欧美在线视频导航| 亚洲大胆人体视频| 欧美日韩美女在线观看| 亚洲网址在线| 老司机午夜精品视频在线观看| 亚洲三级毛片| 国产精品美女久久久| 久久久久久网站| 亚洲精品视频一区二区三区| 亚洲欧美文学| 亚洲高清网站| 国产精品入口麻豆原神| 久久久中精品2020中文| 日韩一级在线观看| 久久免费视频在线观看| 亚洲精品一区二区三区福利| 国产精品入口福利| 欧美国产精品久久| 欧美专区一区二区三区| 最新亚洲一区| 久久久综合网站| 中文日韩电影网站| 影音国产精品| 国产九九视频一区二区三区| 欧美成人情趣视频| 亚洲免费在线电影| 亚洲精品一区二区三| 久久亚洲高清| 西西人体一区二区| 日韩网站在线观看| 在线欧美视频| 国产欧美一区二区三区视频| 欧美精品一区二区三区视频| 久久久av毛片精品| 亚洲性线免费观看视频成熟| 91久久国产精品91久久性色| 久久天天躁狠狠躁夜夜av| 亚洲午夜av在线| 亚洲精品在线看| 在线国产精品播放| 国产亚洲精品一区二区| 国产精品久久99| 欧美日韩中文字幕精品| 欧美成人久久| 猫咪成人在线观看| 久久亚洲私人国产精品va| 销魂美女一区二区三区视频在线| 99re66热这里只有精品3直播| 亚洲第一区色| 欧美成熟视频| 亚洲大胆美女视频| 牛牛国产精品| 欧美成ee人免费视频| 久久影视三级福利片| 久久成人精品无人区| 小辣椒精品导航| 欧美一区二区三区日韩视频| 亚洲男人第一网站| 午夜在线播放视频欧美| 欧美一区视频| 久久精品国产99国产精品| 欧美在线视频全部完| 久久久精品国产免大香伊 | 最新国产成人av网站网址麻豆| 黄色av一区| 亚洲国产精品综合| 亚洲精品中文字幕女同| 日韩视频国产视频| 在线视频你懂得一区| 亚洲一区国产视频| 欧美伊人久久| 久热re这里精品视频在线6| 女生裸体视频一区二区三区| 欧美成人xxx| 亚洲精品久久久久| 亚洲在线免费| 久久久综合网| 欧美精品日韩一本| 国产精品久久久久一区二区三区共| 国产伦精品一区二区三区免费 | 韩国成人理伦片免费播放| 狠狠色丁香婷婷综合久久片| 在线观看欧美一区| 日韩亚洲精品视频| 欧美一区二区在线看| 久久久亚洲精品一区二区三区| 欧美不卡三区| 一区二区三区精品在线| 欧美一区二区三区电影在线观看| 久久久久免费| 欧美日韩三级在线| 国产专区综合网| 亚洲精品乱码久久久久久蜜桃91 | 久久久久久夜精品精品免费| 久久免费国产精品1| 亚洲国产一区二区精品专区| 一区二区高清在线观看| 久久精品中文| 欧美无乱码久久久免费午夜一区| 国内精品久久久久影院薰衣草| 亚洲精品看片| 久久一区二区三区av| 一本久道久久综合婷婷鲸鱼| 久久精品国产视频| 国产精品成人观看视频免费| 亚洲国产精品久久久久秋霞不卡| 亚洲一区www| 亚洲国产成人精品久久| 欧美在线免费一级片| 国产精品福利网|