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

The Fourth Dimension Space

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

POJ 1095 卡特蘭數+dfs

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

#include<stdio.h>
long long a[20];  
long long b[20]; 
//定理:n個結點能形成的二叉樹總數為 卡特蘭數 C(2n,n)/(n+1) 或者由遞推公式Ci+1=2*(2*i+1)/(i+2)*Ci 
//設計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代表有幾個結點,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是此時左子樹掛的節點數
    {        
        printf(
"(");  
        figure(b[i
-1]+1+(n-1)/a[j-1-i]);//初始的時刻,只需要增加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) ;//卡特蘭數遞推公式
        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 卡特蘭數+dfs 2010-04-13 19:37 abilitytao

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

而rand()是以剛才生成的種子為基礎來產生一個隨機數,每調用一次產生一個數,貌似如果期間沒有再次調用srand來生成種子,rand()是接著前面的序列來產生下一個數。(個人想法)
因為:
srand(time(NULL));
int x = rand();
int y = rand();
x和y的值不一樣。而:
srand(time(NULL));
int x = rand();
srand(time(NULL));
int y = rand();
則是相同,因為后一種使用了同一個種子(運行期間時間很短,返回的秒數相同)  回復  更多評論   

# re: POJ 1095 卡特蘭數+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  回復  更多評論   

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

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

# re: POJ 1095 卡特蘭數+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  回復  更多評論   

# re: POJ 1095 卡特蘭數+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.  回復  更多評論   


只有注冊用戶登錄后才能發表評論。
網站導航: 博客園   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>
            亚洲视频在线观看免费| 久久精品国产欧美亚洲人人爽| 久久综合中文| 久久本道综合色狠狠五月| 国精产品99永久一区一区| 久久蜜桃香蕉精品一区二区三区| 久久久精品视频成人| 国外视频精品毛片| 免播放器亚洲一区| 欧美久久久久中文字幕| 亚洲一区二区av电影| 午夜精品美女久久久久av福利| 国产亚洲一级高清| 亚洲国产精品一区| 欧美日韩国产成人在线| 羞羞漫画18久久大片| 久久久女女女女999久久| 亚洲国产精品激情在线观看| 99国产精品久久久久老师| 国产精品久久久久久久久免费 | 亚洲国产高清一区| 亚洲国产综合在线看不卡| 欧美性做爰毛片| 久久精品亚洲| 欧美激情亚洲| 久久精品国产清高在天天线| 免费观看一区| 亚洲欧美成人一区二区三区| 久久一区二区三区四区| 亚洲视频一二区| 久久午夜视频| 亚洲综合精品一区二区| 老司机精品导航| 欧美一二区视频| 欧美高清在线观看| 久久久久久电影| 欧美日韩亚洲一区二区三区四区| 久久久国产亚洲精品| 欧美日韩一区二区三区| 欧美 日韩 国产在线| 国产精品视频一| 日韩亚洲综合在线| 亚洲第一中文字幕| 午夜一区在线| 亚洲欧美一区二区三区久久| 欧美福利视频| 牛牛国产精品| 国内一区二区三区| 午夜欧美大尺度福利影院在线看| 在线综合亚洲| 欧美激情一区二区三区四区| 老司机aⅴ在线精品导航| 国产精品免费一区二区三区观看| 亚洲欧洲综合另类在线| 在线看国产日韩| 久久激情视频| 久久久精品tv| 国产色综合网| 性欧美大战久久久久久久免费观看 | 亚洲欧美综合国产精品一区| 亚洲视频一区二区| 欧美日韩精品一区二区天天拍小说 | 香蕉久久国产| 欧美一级在线播放| 国产精品香蕉在线观看| 亚洲午夜一级| 欧美中在线观看| 国产精自产拍久久久久久| 亚洲在线视频观看| 久久aⅴ国产欧美74aaa| 国产婷婷色一区二区三区在线| 亚洲小视频在线| 欧美一区国产一区| 国产一区二区三区四区| 久久精品视频一| 欧美成人久久| 99www免费人成精品| 欧美日本精品| 亚洲在线免费| 久久亚洲二区| 亚洲二区三区四区| 欧美猛交免费看| 亚洲性夜色噜噜噜7777| 久久久99国产精品免费| 亚洲国产美女久久久久 | 一本大道久久a久久综合婷婷 | 午夜精品免费视频| 国产日韩亚洲| 毛片av中文字幕一区二区| 亚洲国产另类精品专区 | 在线中文字幕日韩| 国产九九精品| 蜜桃久久av| 一区二区三区日韩欧美| 久久久天天操| 99re66热这里只有精品4| 国产精品激情| 美日韩在线观看| 国产精品99久久久久久有的能看| 欧美综合国产精品久久丁香| 亚洲二区免费| 国产精品天天摸av网| 麻豆91精品91久久久的内涵| a4yy欧美一区二区三区| 可以免费看不卡的av网站| 一本色道久久88综合日韩精品| 国产精品美女久久久久av超清 | 欧美理论电影在线观看| 亚洲欧美变态国产另类| 亚洲成人在线视频播放 | aaa亚洲精品一二三区| 国产亚洲欧美色| 欧美日韩视频在线观看一区二区三区| 亚洲欧美日韩综合| 亚洲精品一二| 欧美va亚洲va日韩∨a综合色| 亚洲色在线视频| 亚洲国产日韩欧美综合久久| 国产伦一区二区三区色一情| 欧美极品在线观看| 另类尿喷潮videofree| 亚洲欧美日韩一区在线| 99精品热6080yy久久 | 欧美亚洲一区| 一本一本a久久| 亚洲国产一区二区视频| 国产在线视频欧美| 国产精品亚洲第一区在线暖暖韩国| 欧美国产视频在线| 久久综合九色综合久99| 久久er99精品| 欧美一区二视频在线免费观看| 一区二区三区日韩精品| 日韩视频―中文字幕| 亚洲国产欧美日韩| 欧美激情一区| 欧美激情视频在线播放| 欧美肥婆在线| 欧美激情一区二区三区在线视频观看| 久久久一二三| 久久综合999| 久久午夜精品一区二区| 久久久久综合| 快播亚洲色图| 欧美不卡视频一区| 亚洲国产成人久久综合一区| 欧美国产视频在线| 欧美国产先锋| 亚洲精品美女久久7777777| 亚洲欧洲三级| 夜夜爽av福利精品导航 | 久久亚洲一区二区| 久久精品欧美日韩精品| 久久青草欧美一区二区三区| 久久久久欧美精品| 欧美成人免费网| 亚洲电影在线播放| 亚洲精品久久久久久下一站| 日韩亚洲欧美成人| 亚洲一级高清| 久久国产天堂福利天堂| 麻豆精品国产91久久久久久| 欧美高清一区二区| 国产精品二区在线观看| 国产欧美一区二区三区久久| 伊人久久男人天堂| 日韩视频免费| 欧美一站二站| 欧美大片一区| 一区二区三区波多野结衣在线观看| 亚洲午夜精品久久久久久app| 午夜精品久久久久久久99热浪潮| 欧美一级大片在线免费观看| 蜜臀av国产精品久久久久| 欧美日韩国语| 国产一区二区欧美| 日韩视频一区| 久久九九精品99国产精品| 亚洲丰满在线| 亚洲欧美日韩天堂一区二区| 欧美阿v一级看视频| 国产精品久久久久久久久免费桃花| 国语自产精品视频在线看抢先版结局| 亚洲人成人一区二区三区| 亚洲欧美在线网| 亚洲福利免费| 欧美伊久线香蕉线新在线| 欧美黄色aa电影| 国产原创一区二区| 中文网丁香综合网| 欧美不卡高清| 午夜国产精品视频免费体验区| 欧美黄色aa电影| 黄色国产精品一区二区三区| 亚洲欧美激情视频| 亚洲国语精品自产拍在线观看| 久久国产手机看片| 国产精品免费在线| 亚洲视频在线观看| 亚洲黄色天堂|