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

The Fourth Dimension Space

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

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

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

#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)下的序號(hào)    
    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 閱讀(2150) 評(píng)論(5)  編輯 收藏 引用

評(píng)論

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

srand(time(NULL))
是以當(dāng)前到1970年的時(shí)間間隔的秒數(shù)為種子,time(NULL),指不需要保存一個(gè)時(shí)間對(duì)象
通常情況下可以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ù)  更多評(píng)論   

# 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ù)  更多評(píng)論   

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

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

# 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ù)  更多評(píng)論   

# 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ù)  更多評(píng)論   


只有注冊(cè)用戶登錄后才能發(fā)表評(píng)論。
網(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>
            噜噜噜躁狠狠躁狠狠精品视频| 好看的av在线不卡观看| 亚洲一区二区高清| 亚洲香蕉成视频在线观看| 亚洲欧洲一区二区天堂久久| 欧美高清视频一区二区| 亚洲国产精品一区| 一区二区久久久久久| 国内精品久久久久久久影视蜜臀| 欧美性事在线| 国产视频在线观看一区二区三区 | 欧美激情亚洲国产| 欧美日韩亚洲国产精品| 亚洲欧美一区二区精品久久久| 99在线|亚洲一区二区| 亚洲国产精品久久精品怡红院| 亚洲黄色在线| 欧美一级理论片| 欧美成人免费一级人片100| 最新国产成人av网站网址麻豆 | 亚洲精品乱码久久久久久| 99国产精品视频免费观看| 亚洲女女女同性video| 久久久国产成人精品| 亚洲欧洲视频在线| 午夜精品视频在线| 欧美精彩视频一区二区三区| 国产欧美日韩免费| 一本色道久久88综合日韩精品 | 中文欧美在线视频| 久久久久久免费| 一本色道久久综合亚洲精品高清| 久久成人综合视频| 国产精品久久久久久久久借妻| 在线日韩日本国产亚洲| 午夜视频一区在线观看| 亚洲国产日韩欧美在线图片 | 久久成人精品一区二区三区| 欧美欧美全黄| 亚洲国产天堂久久综合| 久久久久国产精品一区三寸| 亚洲久久成人| 欧美成人精品福利| 亚洲电影激情视频网站| 欧美一区视频| 这里是久久伊人| 欧美日韩国产成人在线观看| 亚洲国产精品va在线看黑人动漫| 欧美在线啊v一区| 99国产精品久久久久老师| 欧美福利在线| 亚洲精品免费一二三区| 欧美高清不卡在线| 久久综合五月| 亚洲第一精品夜夜躁人人爽 | 欧美 日韩 国产一区二区在线视频 | 久久国产精品高清| 国产欧美日韩亚洲一区二区三区| 亚洲中午字幕| 亚洲性视频h| 国产农村妇女毛片精品久久麻豆| 国产日韩综合一区二区性色av| 亚洲视频一区在线| 99在线视频精品| 欧美午夜精品久久久久久浪潮| 一区二区av| 中国成人在线视频| 国产精品网站在线播放| 欧美影院视频| 欧美在线视频二区| 激情久久五月天| 欧美激情精品久久久久久变态| 欧美成人嫩草网站| 在线视频免费在线观看一区二区| 欧美国产亚洲视频| 欧美日韩一区二区三区高清| 亚洲免费小视频| 欧美在线观看一二区| 亚洲二区视频| 夜夜嗨av色综合久久久综合网| 国产精品久久久久久久电影| 久久精品亚洲一区| 欧美xart系列高清| 亚洲宅男天堂在线观看无病毒| 午夜日韩电影| 亚洲全部视频| 亚洲一级片在线观看| 黄色影院成人| 日韩亚洲欧美高清| 国产女主播一区二区三区| 久久夜色精品国产噜噜av| 欧美激情久久久久| 久久精品国产综合精品| 欧美第一黄色网| 欧美在线免费观看视频| 免费人成精品欧美精品| 亚洲一区图片| 欧美刺激午夜性久久久久久久| 亚洲欧美在线一区二区| 狼狼综合久久久久综合网| 亚洲欧美久久久| 欧美成人免费视频| 久久se精品一区二区| 欧美激情精品久久久久久蜜臀| 久久国产欧美日韩精品| 欧美日韩国产一区精品一区 | 中文亚洲视频在线| 亚洲国产精品欧美一二99| 亚洲欧美视频一区| 亚洲六月丁香色婷婷综合久久| 午夜在线精品| 亚洲一区二区三区777| 免费观看欧美在线视频的网站| 欧美一区二区私人影院日本| 欧美日韩亚洲三区| 亚洲高清免费视频| 伊甸园精品99久久久久久| 亚洲欧美日韩直播| 亚洲欧美中文另类| 欧美日产在线观看| 亚洲黄页视频免费观看| 在线观看亚洲一区| 久久成人国产| 久久精品夜色噜噜亚洲a∨| 国产精品伊人日日| 欧美中文在线免费| 国产精品99免费看| 夜夜嗨av一区二区三区| 99成人精品| 欧美成人高清视频| 欧美激情久久久久| 亚洲国产高清一区| 免费精品视频| 欧美aⅴ一区二区三区视频| 黄色亚洲网站| 久久久久国产精品一区三寸| 久久精品国产第一区二区三区最新章节 | 狼人天天伊人久久| 免费影视亚洲| 亚洲国产欧美日韩精品| 久久亚洲综合| 亚洲丶国产丶欧美一区二区三区 | 国产欧美日韩精品专区| 午夜欧美视频| 免费人成精品欧美精品| 亚洲黄色三级| 欧美日韩亚洲成人| 亚洲一区二区三区中文字幕| 久久成人18免费网站| 国产一区二区无遮挡| 久久免费黄色| 亚洲精品日韩在线| 亚洲欧美日韩网| 韩国久久久久| 欧美精品一区二区三区四区| 日韩一级片网址| 久久精品国产91精品亚洲| 在线日韩av永久免费观看| 欧美日韩国产精品自在自线| 亚洲永久免费av| 亚洲电影网站| 欧美在线播放视频| 亚洲人成在线播放| 国产精品色在线| 麻豆精品精品国产自在97香蕉| 亚洲精品综合| 老司机午夜精品视频在线观看| 99re国产精品| 国产一区二三区| 欧美日韩国产精品一区二区亚洲| 亚洲欧美一区二区三区在线| 欧美成人高清| 亚洲欧美视频在线观看| 亚洲国产经典视频| 国产精品一二一区| 你懂的视频一区二区| 亚洲夜晚福利在线观看| 暖暖成人免费视频| 午夜精品视频在线| 亚洲美女精品久久| 精品成人久久| 国产女人aaa级久久久级| 牛牛精品成人免费视频| 亚洲免费视频观看| 亚洲片在线资源| 免费观看在线综合色| 欧美一级日韩一级| 亚洲一区激情| 99re66热这里只有精品3直播| 韩曰欧美视频免费观看| 国产精品久久久久一区二区三区| 欧美成人第一页| 欧美呦呦网站| 亚洲国产精品精华液网站| 欧美一区精品| 亚洲伊人网站| 亚洲一二三区在线观看| 亚洲精品一区二区三区四区高清 | 久久久国产一区二区| 亚洲一区中文|