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

Sephiroth's boring days!!!

Love just for you.

樹(shù)形動(dòng)態(tài)規(guī)劃-三色二叉樹(shù)

【問(wèn)題描述】

一棵二叉樹(shù)可以按照如下規(guī)則表示成一個(gè)由0、1、2 組成的字符序列,我們稱(chēng)之為“二叉樹(shù)序列S”:

2表示該樹(shù)有兩個(gè)子節(jié)點(diǎn), 和分別表示其兩個(gè)子樹(shù)的二叉樹(shù)序列

1表示該樹(shù)有一個(gè)子節(jié)點(diǎn), 為其子樹(shù)的二叉樹(shù)序列

0表示該樹(shù)沒(méi)有子節(jié)點(diǎn)

你的任務(wù)是要對(duì)一棵二叉樹(shù)的節(jié)點(diǎn)進(jìn)行染色。每個(gè)節(jié)點(diǎn)可以被染成紅色、綠色或藍(lán)色。并且,一個(gè)節(jié)點(diǎn)與其子節(jié)點(diǎn)的顏色必須不同,如果該節(jié)點(diǎn)有兩個(gè)子節(jié)點(diǎn),那么這兩個(gè)子節(jié)點(diǎn)的顏色也必須不相同。給定一棵二叉樹(shù)的二叉樹(shù)序列,請(qǐng)求出這棵樹(shù)中最多和最少有多少個(gè)點(diǎn)能夠被染成綠色。

【輸入文件】

輸入文件名:TRO.IN

輸入文件僅有一行,不超過(guò)10000 個(gè)字符,表示一個(gè)二叉樹(shù)序列。

【輸出文件】

輸出文件名:TRO.OUT

輸出文件也只有一行,包含兩個(gè)數(shù),依次表示最多和最少有多少個(gè)點(diǎn)能夠被

染成綠色。

【樣例輸入】

1122002010

【樣例輸出】

5 2

【分析】

1.動(dòng)歸分析

拿最大來(lái)說(shuō)。

每個(gè)節(jié)點(diǎn)的狀態(tài)只有三種顏色,我們用f[i][0],f[i][1]分別代表第i個(gè)點(diǎn)染綠色和不然綠色的最多的點(diǎn)數(shù)。因?yàn)槿绻粋€(gè)點(diǎn)不染綠色,那么他染另兩種顏色是等價(jià)的。如此我們就得到了如下的動(dòng)規(guī)方程:

  • 葉子:f[i][0]=1; f[i][1]=0;
  • 一個(gè)子節(jié)點(diǎn):f[i][0]=f[子節(jié)點(diǎn)][1]; f[i][1]=max(f[子節(jié)點(diǎn)][0],f[子節(jié)點(diǎn)][1]);
  • 兩個(gè)子節(jié)點(diǎn):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.樹(shù)的確定

因?yàn)槭且豢枚鏄?shù)的前序遍歷,那么對(duì)于一個(gè)有子節(jié)點(diǎn)的點(diǎn)來(lái)說(shuō),左兒子就是i+1。我們引進(jìn)一個(gè)link[i],表示以i為根的子樹(shù)最后一個(gè)點(diǎn)的標(biāo)號(hào),那么r[i]=link[l[i]]+1。

對(duì)于link[l],我們?nèi)绱舜_定:

  • 葉子:link[l]=l;
  • 一個(gè)子節(jié)點(diǎn):link[l]=link[l+1];
  • 兩個(gè)子節(jié)點(diǎn):link[l]=link[link[l+1]+1];

然后就是實(shí)現(xiàn)了。因?yàn)樽约号眠€是不是很熟,打了兩節(jié)課。

  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) 評(píng)論(0)  編輯 收藏 引用 所屬分類(lèi): 信息奧賽

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>
            老司机午夜精品视频在线观看| 亚洲欧美一区二区三区极速播放| 久久精品国产久精国产爱| 亚洲永久视频| 欧美一区二区三区在线观看视频 | 久久久www成人免费毛片麻豆| 亚洲一区二区三区在线观看视频| 亚洲午夜av电影| 午夜激情一区| 久久久亚洲高清| 欧美大片第1页| 91久久精品日日躁夜夜躁国产| 蜜桃久久精品一区二区| 亚洲国产综合在线| 中文网丁香综合网| 久久精品五月婷婷| 欧美精品一区二区三区在线看午夜 | 久久中文欧美| 欧美风情在线| 国产精品盗摄久久久| 国产日韩视频| 日韩图片一区| 欧美在线亚洲在线| 久久久久免费视频| 亚洲天堂av在线免费| 欧美一区二区在线视频| 久久在线精品| 国产精品成人播放| 在线不卡a资源高清| 亚洲一区二区三区影院| 欧美大片在线观看| 亚洲欧美国产高清va在线播| 蜜臀久久久99精品久久久久久| 欧美亚洲第一页| 91久久精品国产91久久| 欧美中文在线观看| 日韩视频专区| 免费精品视频| 韩国精品一区二区三区| 亚洲永久免费观看| 亚洲国语精品自产拍在线观看| 亚洲一区在线观看视频| 欧美电影在线观看| 狠色狠色综合久久| 欧美一区二区三区在线视频 | 欧美一区二区三区啪啪| 欧美日韩一区二区三| 亚洲高清不卡在线| 久久日韩粉嫩一区二区三区| 欧美精品粉嫩高潮一区二区| 亚洲欧洲精品一区二区三区 | 亚洲天堂成人在线观看| 欧美国产第二页| 久久九九精品99国产精品| 国产精品一区视频| 性欧美videos另类喷潮| 亚洲天堂成人| 国产欧美日韩不卡| 亚洲综合色视频| 一本色道88久久加勒比精品| 欧美日韩国产在线| 亚洲视频一区在线| 夜夜嗨一区二区三区| 欧美日韩在线看| 亚洲午夜三级在线| 亚洲最新在线| 国产精品福利在线| 午夜激情综合网| 亚洲免费在线精品一区| 国产毛片精品视频| 久久免费视频在线观看| 久久人人爽国产| 最近中文字幕日韩精品| 亚洲经典自拍| 欧美午夜不卡在线观看免费| 亚洲综合视频一区| 午夜激情一区| 欧美综合第一页| 欧美中日韩免费视频| 激情六月婷婷久久| 美国三级日本三级久久99| 久久影院午夜片一区| 亚洲理伦电影| 亚洲午夜在线观看| 国产综合色产| 久久久精品网| 欧美在线首页| 亚洲人成绝费网站色www| 亚洲国产一区二区a毛片| 欧美日韩色一区| 久久国产一区二区| 快射av在线播放一区| 宅男在线国产精品| 久久国产精品久久w女人spa| 亚洲国产精品美女| 正在播放亚洲一区| 影音先锋在线一区| 日韩视频第一页| 国模私拍视频一区| 亚洲精品国产精品乱码不99按摩 | 韩日午夜在线资源一区二区| 欧美成人免费网| 国产精品美女视频网站| 美女主播一区| 欧美三级小说| 欧美二区在线| 国产日韩精品久久| 亚洲美女啪啪| 亚洲高清视频中文字幕| 亚洲在线观看免费视频| 亚洲精品视频在线观看网站| 亚欧成人在线| 亚洲社区在线观看| 欧美成人高清| 久久亚洲综合色| 国产精品视频一| 亚洲人成啪啪网站| 亚洲成人在线| 久久成人18免费网站| 亚洲免费一在线| 欧美欧美在线| 亚洲国产美国国产综合一区二区| 国内外成人免费视频| 亚洲视频免费在线观看| 亚洲成色www8888| 亚洲欧美另类综合偷拍| 一本色道久久综合亚洲精品婷婷| 欧美一区二区三区喷汁尤物| 亚洲伊人久久综合| 欧美日韩在线播放| 日韩视频永久免费观看| 亚洲欧洲精品一区二区三区波多野1战4| 午夜精品久久久久久久久久久久久 | 久久免费少妇高潮久久精品99| 亚洲欧美日本国产有色| 欧美日韩一区三区四区| 亚洲激情在线观看视频免费| 亚洲看片免费| 久久婷婷国产综合尤物精品| av72成人在线| 99热在这里有精品免费| 欧美国产成人精品| 日韩视频在线观看免费| 亚洲中无吗在线| 国产精品一二| 午夜精品久久久久久| 久久久成人精品| 黄色日韩网站视频| 久久久久久久尹人综合网亚洲| 久久琪琪电影院| 亚洲国产三级| 欧美精品国产一区二区| 一区二区91| 亚洲专区在线视频| 国产一区二区在线观看免费| 久久久噜噜噜久久久| 亚洲大片av| 亚洲一区二区在线| 国产无一区二区| 久热精品视频在线观看一区| 亚洲黄色视屏| 亚洲欧美综合| 怡红院精品视频| 欧美人与性动交a欧美精品| 一区二区三区欧美激情| 久久精品国产999大香线蕉| 一区二区在线免费观看| 一本久久青青| 久久精品男女| 亚洲理论在线| 国产日韩精品一区二区浪潮av| 久久中文精品| 亚洲综合清纯丝袜自拍| 欧美1级日本1级| 亚洲自拍偷拍麻豆| 精品成人免费| 欧美午夜电影网| 美女国产精品| 亚洲欧美日韩人成在线播放| 欧美成人久久| 欧美在线观看网址综合| 亚洲精品一区在线观看香蕉| 国产精品综合av一区二区国产馆| 蜜臀av一级做a爰片久久| 亚洲免费视频在线观看| 亚洲乱码精品一二三四区日韩在线 | 亚洲欧美精品一区| 亚洲国产激情| 久久米奇亚洲| 亚洲自拍偷拍麻豆| 亚洲精选一区二区| 一区免费观看| 国产欧美 在线欧美| 欧美日韩国产在线一区| 久久综合给合| 久久久久久久国产| 性色av香蕉一区二区| 在线亚洲美日韩| 亚洲国产精品久久久久秋霞蜜臀 | 欧美在线亚洲综合一区|