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

Sephiroth's boring days!!!

Love just for you.

樹形動態規劃-三色二叉樹

【問題描述】

一棵二叉樹可以按照如下規則表示成一個由0、1、2 組成的字符序列,我們稱之為“二叉樹序列S”:

2表示該樹有兩個子節點, 和分別表示其兩個子樹的二叉樹序列

1表示該樹有一個子節點, 為其子樹的二叉樹序列

0表示該樹沒有子節點

你的任務是要對一棵二叉樹的節點進行染色。每個節點可以被染成紅色、綠色或藍色。并且,一個節點與其子節點的顏色必須不同,如果該節點有兩個子節點,那么這兩個子節點的顏色也必須不相同。給定一棵二叉樹的二叉樹序列,請求出這棵樹中最多和最少有多少個點能夠被染成綠色。

【輸入文件】

輸入文件名:TRO.IN

輸入文件僅有一行,不超過10000 個字符,表示一個二叉樹序列。

【輸出文件】

輸出文件名:TRO.OUT

輸出文件也只有一行,包含兩個數,依次表示最多和最少有多少個點能夠被

染成綠色。

【樣例輸入】

1122002010

【樣例輸出】

5 2

【分析】

1.動歸分析

拿最大來說。

每個節點的狀態只有三種顏色,我們用f[i][0],f[i][1]分別代表第i個點染綠色和不然綠色的最多的點數。因為如果一個點不染綠色,那么他染另兩種顏色是等價的。如此我們就得到了如下的動規方程:

  • 葉子:f[i][0]=1; f[i][1]=0;
  • 一個子節點:f[i][0]=f[子節點][1]; f[i][1]=max(f[子節點][0],f[子節點][1]);
  • 兩個子節點:f[i][0]=f[左兒子][1]+f[右兒子][1]; f[i][1]=max(f[左兒子][1]+f[右兒子][0],f[左兒子][0]+f[右兒子][1]);

最后輸出就是max(f[0][1],f[0][0])。

最小的和最大的相同。

2.樹的確定

因為是一棵二叉樹的前序遍歷,那么對于一個有子節點的點來說,左兒子就是i+1。我們引進一個link[i],表示以i為根的子樹最后一個點的標號,那么r[i]=link[l[i]]+1。

對于link[l],我們如此確定:

  • 葉子:link[l]=l;
  • 一個子節點:link[l]=link[l+1];
  • 兩個子節點:link[l]=link[link[l+1]+1];

然后就是實現了。因為自己弄得還是不是很熟,打了兩節課。

  1: #include <stdio.h>
  2: #include <string.h>
  3: #include <iostream>
  4: #define maxn 10010
  5: #define MAXINT 10000000
  6: using namespace std;
  7: 
  8: char s[maxn];
  9: int f[maxn][2];
 10: int link[maxn];
 11: int n;
 12: int l[maxn],r[maxn];
 13: 
 14: int _find(int x)
 15: {
 16:     if (link[x]) return link[x];
 17:     if (s[x]=='0') link[x]=x;
 18:     else
 19:         if (s[x]=='1') link[x]=_find(x+1);
 20:         else
 21:             link[x]=_find(_find(x+1)+1);
 22:     return link[x];
 23: }
 24: 
 25: void find1(int x)
 26: {
 27:     if (f[x][0]) return;
 28:     if (s[x]=='0')
 29:     {
 30:         f[x][0]=1;
 31:         f[x][1]=0;
 32:     }
 33:     else
 34:         if (s[x]=='1')
 35:         {
 36:             find1(l[x]);
 37:             f[x][0]=f[l[x]][1]+1;
 38:             f[x][1]=max(f[l[x]][1],f[l[x]][0]);
 39:         }
 40:         else
 41:         {
 42:             find1(l[x]);
 43:             find1(r[x]);
 44:             f[x][0]=f[l[x]][1]+f[r[x]][1]+1;
 45:             f[x][1]=max(f[l[x]][1]+f[r[x]][0],f[l[x]][0]+f[r[x]][1]);
 46:         }
 47: }
 48: 
 49: void find2(int x)
 50: {
 51:     if (f[x][0]<MAXINT) return;
 52:     if (s[x]=='0')
 53:     {
 54:         f[x][0]=1;
 55:         f[x][1]=0;
 56:     }
 57:     else
 58:         if (s[x]=='1')
 59:         {
 60:             find2(l[x]);
 61:             f[x][0]=f[l[x]][1]+1;
 62:             f[x][1]=min(f[l[x]][1],f[l[x]][0]);
 63:         }
 64:         else
 65:         {
 66:             find2(l[x]);
 67:             find2(r[x]);
 68:             f[x][0]=f[l[x]][1]+f[r[x]][1]+1;
 69:             f[x][1]=min(f[l[x]][1]+f[r[x]][0],f[l[x]][0]+f[r[x]][1]);
 70:         }
 71: }
 72: 
 73: int main()
 74: {
 75:     freopen("tro.in","r",stdin);
 76:     freopen("tro.out","w",stdout);
 77:     
 78:     scanf("%s",s);
 79:     n=strlen(s);
 80:     _find(0);
 81:     for (int i=0;i<n;++i)
 82:     {
 83:         l[i]=i+1;
 84:         r[i]=link[l[i]]+1;
 85:     }
 86:     find1(0);
 87:     printf("%d ",max(f[0][0],f[0][1]));
 88:     for (int i=0;i<n;++i)
 89:         f[i][0]=f[i][1]=MAXINT;
 90:     find2(0);
 91:     printf("%d\n",min(f[0][0],f[0][1]));
 92:     return 0;
 93: }
 94: 

posted on 2010-09-01 21:41 Sephiroth Lee 閱讀(778) 評論(0)  編輯 收藏 引用 所屬分類: 信息奧賽

free counters
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            中日韩美女免费视频网址在线观看| 亚洲日本一区二区| 亚洲欧美日韩一区二区在线| 欧美日韩不卡一区| 亚洲午夜精品视频| 香蕉精品999视频一区二区| 国产视频在线观看一区二区| 欧美在线免费观看视频| 蘑菇福利视频一区播放| 日韩亚洲不卡在线| 国产精品久久久久影院色老大| 亚洲一区二区视频在线| 免费在线日韩av| 亚洲国产欧美一区二区三区丁香婷| 久久国产精品久久久久久| 免费日韩av| 性做久久久久久久免费看| 欧美中文字幕在线| 久久在线观看视频| 久久一区二区三区国产精品| 欧美激情一区二区三区不卡| 亚洲宅男天堂在线观看无病毒| 伊人精品久久久久7777| 欧美日韩国产不卡在线看| 欧美日韩亚洲一区三区| 蜜臀av国产精品久久久久| 亚洲在线成人精品| 麻豆国产精品777777在线| 欧美日本国产| 欧美成人蜜桃| 久久久人人人| 久久久777| 欧美一区二区三区免费看| 亚洲精品婷婷| 欧美成人dvd在线视频| 亚洲美女在线视频| 亚洲欧洲久久| 欧美激情精品久久久久久蜜臀| 一区二区免费看| 99精品欧美一区二区三区| 亚洲久色影视| 久久天天躁狠狠躁夜夜爽蜜月| 欧美午夜不卡视频| 国产精品美女xx| 日韩网站在线观看| 乱中年女人伦av一区二区| 欧美.www| 欧美一区二区福利在线| 国产精品xvideos88| 亚洲美女一区| 亚洲与欧洲av电影| 亚洲国产成人高清精品| 亚洲国产欧美另类丝袜| 久久九九国产精品| 国产精品午夜久久| 国产精自产拍久久久久久蜜| 国产亚洲福利| 亚洲高清在线| 亚洲人成在线观看一区二区| 日韩一区二区精品在线观看| 欧美a一区二区| 久久成人精品电影| 国产一区二区三区在线观看精品| 午夜宅男欧美| 篠田优中文在线播放第一区| 欧美一级视频免费在线观看| 国产精品视频观看| 新67194成人永久网站| 亚洲欧美日韩国产一区二区三区| 久久亚洲春色中文字幕| 一色屋精品亚洲香蕉网站| 国产精品一区二区久久精品| 欧美日韩精品综合在线| 亚洲日本一区二区三区| 亚洲高清av| 欧美日本一区二区视频在线观看| 亚洲免费黄色| 亚洲一区二区三区涩| 国产日本欧美视频| 亚洲精品国产无天堂网2021| 欧美国产免费| 亚洲一区亚洲二区| 国产午夜精品福利| 欧美风情在线| 欧美日韩精品二区| 午夜久久黄色| 最新日韩在线| 国产精品高清免费在线观看| 亚洲激情啪啪| 欧美一区二区私人影院日本| 亚洲日本成人女熟在线观看| 午夜精品久久久久久久久久久久久 | 男女激情久久| 欧美日韩国产精品一区| 香蕉久久精品日日躁夜夜躁| 久久久噜噜噜久久狠狠50岁| 99国产精品99久久久久久粉嫩| 一区二区av| 亚洲电影第1页| 久久九九热免费视频| 亚洲第一页在线| 欧美日韩国产一区精品一区| 欧美在线综合视频| 欧美精品久久久久a| 在线观看亚洲精品视频| 91久久中文| 国模私拍一区二区三区| 亚洲欧美日韩国产另类专区| 久久精品视频网| 亚洲一区综合| 欧美jjzz| 日韩一级大片在线| 欧美一区网站| 亚洲视频在线播放| 久久色在线播放| 久久精品盗摄| 久久久国产精品一区二区中文| 一本久道久久综合婷婷鲸鱼| 亚洲国产精品ⅴa在线观看| 国产精品美女主播| 亚洲精品一级| 亚洲精选91| 欧美91视频| 欧美成年人视频| 狠狠色狠狠色综合人人| 久久久久9999亚洲精品| 欧美体内谢she精2性欧美| 亚洲欧美综合精品久久成人| 欧美二区在线| 亚洲高清在线视频| 欧美一区二区三区在线看| 欧美jjzz| 亚洲成人在线免费| 性做久久久久久免费观看欧美 | 欧美日韩亚洲综合| 欧美激情视频网站| 精品福利免费观看| 亚洲国产成人久久综合一区| 国产三级欧美三级| 午夜精品一区二区三区电影天堂| 亚洲欧美日韩一区二区在线 | 极品尤物一区二区三区| 久久av一区二区三区漫画| 久久久精品999| 韩国三级电影一区二区| 久久精品视频免费播放| 欧美成人激情在线| 亚洲乱码国产乱码精品精| 欧美日韩成人综合天天影院| 一区二区三区欧美亚洲| 性色av一区二区三区在线观看 | 亚洲精品在线观看免费| 欧美精品18videos性欧美| 日韩一级视频免费观看在线| 亚洲免费影视| 狠狠干狠狠久久| 欧美成人一区二区三区在线观看 | 亚洲福利视频专区| 欧美黑人在线播放| 一区二区三区免费观看| 欧美一级视频一区二区| 国外成人网址| 欧美精品成人| 欧美一级大片在线观看| 欧美激情一区| 先锋影音国产一区| 在线不卡欧美| 欧美视频在线观看一区二区| 欧美在线视频导航| 亚洲日本久久| 久久久久久久久久久久久9999| 亚洲欧洲午夜| 国产精品视频最多的网站| 久久亚洲精品中文字幕冲田杏梨| 亚洲精品在线视频| 久久男女视频| 国产精品免费视频xxxx| 久久久久成人精品免费播放动漫| 亚洲人成网站在线观看播放| 久久精品国产99| 日韩一区二区免费高清| 国内久久婷婷综合| 欧美吻胸吃奶大尺度电影| 久久久久网站| 亚洲欧美综合v| 亚洲免费成人av电影| 免费不卡亚洲欧美| 翔田千里一区二区| 日韩写真视频在线观看| 亚洲欧美日韩综合国产aⅴ| 日韩性生活视频| 激情小说另类小说亚洲欧美| 欧美性猛交一区二区三区精品| 欧美在线一区二区| 亚洲天堂第二页| 亚洲第一在线| 久久精品国产欧美亚洲人人爽| 亚洲小说欧美另类婷婷| 欧美激情视频一区二区三区免费| 午夜日韩av|