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

Onway

我是一只菜菜菜菜鳥...
posts - 61, comments - 56, trackbacks - 0, articles - 34

之所以想到要注釋一下,沒別的意思,只是因?yàn)閹讉€(gè)月前剛學(xué)DP,完全看不懂,前幾天費(fèi)了幾個(gè)小時(shí)終于看懂了,注釋下來,能使自己整理一下思路,也作為自己的一篇日記。

當(dāng)時(shí)我能看懂時(shí)間和空間均為O(MN^2)的函數(shù),但可能由于自己看書是直接從動(dòng)態(tài)規(guī)劃一章看起,書上對(duì)于經(jīng)過優(yōu)化的函數(shù)也沒有更多的解析,當(dāng)時(shí)看起來完全不知所云。前幾天看的時(shí)候,是對(duì)著方程結(jié)合書上的幾句話自己去理解,嘗試自己動(dòng)手去寫,但錯(cuò)了。看書上代碼,都要自己去理解那些變量數(shù)組是干什么用的,感覺也是非常吃力。

1,

我覺得理解那個(gè)優(yōu)化函數(shù),必須先要充分理解那個(gè)二維的DP方程:

b[i][j]=max(b[i][j-1]+a[j],max(b[i-1][t])+a[j])  (i-1<=t<j)

b[i][j]表示的是第i段在前j項(xiàng)(含第j項(xiàng))的最大值。對(duì)于b[i][j]含有第j項(xiàng)必須要理解好!則方程的意思是:對(duì)于a[j]項(xiàng),要么將它加到第i段,要么它自己作為新的一段。

注意到方程外層的max選擇,都要加上a[j]這一項(xiàng)。這里可能很容易產(chǎn)生一個(gè)疑問,如果a[j]是一個(gè)負(fù)數(shù),為什么還要加上a[j]呢?回到b[i][j]所表示的意義上解釋,由于b[i][j]表示的是含有第j項(xiàng)的最大值,所以a[j]是肯定要加進(jìn)來的。假使a[j]是一個(gè)負(fù)數(shù),它加進(jìn)來了也不會(huì)影響在第i段中前j-1項(xiàng)的最大值。

所以第m段的最大值,并不是b[m][n],而是b[m][m~n]之間的最大值。

同樣道理,第i-1段的最大值是b[i-1][t],(i-i<=t<j)。

2,

理解了上述的DP方程后,再來考慮優(yōu)化,正如書上所說的,由于在第i段中,只用到第i段和第i-1段的值。如果采用一維數(shù)組存儲(chǔ)b[],只要在計(jì)算第i段的時(shí)候,沒有去改變第i-1段保留下來的值即可。再考慮到,內(nèi)層max選擇,需要用到第i-1段在i-1到j(luò)-1位置的最大值,不但要進(jìn)行重復(fù)計(jì)算,也影響到b[j]的計(jì)算,因?yàn)閖前面的值既要用作b[j]的計(jì)算,也要更新作為下一段i+1計(jì)算時(shí)所用。

為了解決這個(gè)問題,書上是利用了一個(gè)輔助的一維數(shù)組c[],c[j]保存的是上一段i-1在j位置的最大值。顯然計(jì)算第i段在j位置的值b[j]要用到的c[]的下標(biāo)是從i-1到j(luò)-1的。

那么這時(shí)DP方程可以變?yōu)椋?o:p>

b[j]=max(b[j-1]+a[j],c[j-1]+a[j])

要注意,b[j-1]與c[j-1]是相差一段的,即b[j-1]計(jì)算的是第i段的值,而c[j-1]記錄的是i-1段的值。

這里有一個(gè)關(guān)鍵是對(duì)c[]在計(jì)算第i段值b[j]的時(shí)候,要及時(shí)更新,以作計(jì)算下一段使用。

3,

以上的具體實(shí)現(xiàn)自己寫不出來,還是照看書上的代碼,略作解析。其實(shí)明白了上面說明的兩段,書上代碼是很好理解的。書上對(duì)于邊界條件的處理,我覺得做得非常好,而我也正是錯(cuò)在這個(gè)地方。

int MaxSum(int m,int n,int *a)
{
    
if(n<m||m<1)    return 0;
    
int *b=new int[n+1];    //b[j]保存的是第i段中在前j(含j)項(xiàng)的最大值
    int *c=new int[n+1];    //c[j]保存的是i-1段中在i-1到j(luò)(含j)項(xiàng)中的最大值
                            
//注意,以上b[j]和c[j]都是指在計(jì)算第i段時(shí)的值;
    b[0]=0;
    c[
1]=0;                 //第0段時(shí)的兩個(gè)值,初始化邊界條件 
    for(int i=1;i<=m;i++)   //i為當(dāng)前計(jì)算段數(shù) 
    {
        b[i]
=b[i-1]+a[i];    //b[i]即b[j]在j=i時(shí)的值,由于j=i,每一個(gè)項(xiàng)都要成為一段,這就是邊界條件
        c[i-1]=b[i];        //這里很繞,其實(shí)這句是沒用的,因?yàn)樵诘趇段中數(shù)組c[]保存的值是為下一
                            
//段i+1服務(wù)的,i+1段只用到c[i],可以直接刪掉,免得誤導(dǎo)                        
        int max=b[i];        //max記錄第i段的從i位置開始所有能用到的項(xiàng)的最大值
        for(int j=i+1;j<=i+n-m;j++)
        {
            b[j]
=b[j-1]>c[j-1]?b[j-1]+a[j]:c[j-1]+a[j];//這里用到的c[j-1]
                                                      
//是沒被修改的,還是上一段i-1中在j-1位置的最大值
            c[j-1]=max;            //用完后就要修改為第i段中在j-1位置的最大值,明顯,max是記錄了第i段中的
            if(max<b[j])        //在j-1位置的最大值,盡管當(dāng)前循環(huán)中計(jì)算的是第j項(xiàng)
                max=b[j];        //更新max的值
        }
        c[i
+n-m]=max;    //由于max記錄的項(xiàng)總比循環(huán)的j項(xiàng)小1,所以第i段在最后一項(xiàng)中的最大值放在循環(huán)外更新
    }

    
int sum=0;        //默認(rèn)全是負(fù)數(shù)的時(shí)候,最大值是0,如果要計(jì)算負(fù)的最大值,可以將sum設(shè)為一個(gè)大負(fù)數(shù)
    for(int j=m;j<=n;j++)    //為什么還有一次循環(huán)找最大值,而不是直接使用b[n]呢?因?yàn)閎[j]包含了a[j],
        if(sum<b[j])        //在b[j]的值不一定比不包含a[j]的其他項(xiàng)大。
            sum=b[j];
    
return sum;
}

附:pku 2479就是一題求最大2段和。
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            亚洲精品久久7777| 国产精品区一区| 一区二区黄色| 日韩亚洲精品在线| 一本色道久久综合一区| 这里只有精品视频| 亚洲欧美日韩一区| 亚洲欧美日韩在线高清直播| 久久精品视频免费观看| 久久精品成人一区二区三区蜜臀| 久久综合激情| 欧美日韩国语| 国产欧美日韩另类视频免费观看| 国产情人综合久久777777| 黄色影院成人| 一区二区三区高清视频在线观看| 久久爱另类一区二区小说| 久久久蜜桃精品| 欧美 日韩 国产在线| 91久久在线| 一区二区三区 在线观看视| 亚洲一区视频在线| 蜜乳av另类精品一区二区| 国产精品二区影院| 精品成人在线视频| 亚洲一区二区三区在线播放| 久久久国产成人精品| 亚洲欧洲日韩女同| 久久国产免费看| 欧美午夜电影在线观看| 在线日韩中文| 欧美自拍偷拍| 99ri日韩精品视频| 玖玖视频精品| 国产一区二区成人| 亚洲综合精品| 亚洲福利国产| 久久手机精品视频| 国产欧美视频在线观看| 亚洲图片欧美一区| 亚洲狠狠婷婷| 你懂的国产精品| 一区在线观看| 久久色在线播放| 午夜日韩在线观看| 国产精品青草综合久久久久99| 日韩亚洲欧美成人| 亚洲大胆女人| 久久在线免费观看视频| 狠狠狠色丁香婷婷综合久久五月| 亚洲影视在线播放| 妖精成人www高清在线观看| 欧美成年人在线观看| 亚洲国产精品一区| 欧美激情片在线观看| 久久精品国产2020观看福利| 国产精品日韩欧美一区二区| 亚洲在线免费| 亚洲欧美三级伦理| 国产欧美欧美| 久久久久久亚洲精品中文字幕 | 亚洲一区二区动漫| 欧美日一区二区在线观看 | 国产女人18毛片水18精品| 午夜国产不卡在线观看视频| 宅男在线国产精品| 国产日韩精品电影| 欧美高潮视频| 国产欧美在线看| 久久精品国产999大香线蕉| 亚洲欧美日韩另类| 国产视频久久网| 久热这里只精品99re8久| 久久精品电影| 亚洲精品乱码久久久久久日本蜜臀 | 国产日韩欧美二区| 麻豆精品91| 免费欧美在线视频| 夜夜嗨av色一区二区不卡| 一本色道久久综合狠狠躁篇怎么玩| 欧美视频中文一区二区三区在线观看| 亚洲综合不卡| 久久人人九九| 亚洲一区二区视频在线观看| 亚洲香蕉伊综合在人在线视看| 国产欧美一区二区三区另类精品| 久久久亚洲国产美女国产盗摄| 嫩草国产精品入口| 亚洲综合导航| 久热精品视频在线免费观看| 中国成人黄色视屏| 欧美在线观看视频在线| 最新国产精品拍自在线播放| 亚洲视频在线二区| 亚洲国产婷婷综合在线精品| 一区二区高清在线| 亚洲国产精品99久久久久久久久| 日韩一级精品视频在线观看| 久久精品国亚洲| 一本色道久久综合狠狠躁的推荐| 欧美一区二区女人| 中日韩高清电影网| 老巨人导航500精品| 午夜欧美不卡精品aaaaa| 久久香蕉国产线看观看av| 亚洲一区二区黄| 免费观看久久久4p| 欧美一区二区日韩一区二区| 欧美激情综合五月色丁香| 久久国产精品毛片| 欧美午夜精品久久久久免费视| 老色鬼精品视频在线观看播放| 欧美日韩黄色大片| 亚洲大片免费看| 黄色日韩精品| 午夜久久tv| 欧美一区二区三区成人| 欧美日韩久久精品| 亚洲欧洲精品一区二区三区不卡 | 黄色日韩网站视频| 亚洲网站在线观看| 久久久国产视频91| 亚洲日本中文字幕区| 欧美日韩天天操| 久久久九九九九| 久久成人精品| 一区二区激情| 99re6这里只有精品| 国产乱肥老妇国产一区二| 久久久久久一区二区三区| 欧美人在线观看| 欧美大片国产精品| 亚洲第一色在线| 久久精品夜色噜噜亚洲aⅴ| 久久99伊人| 国产午夜一区二区三区| 午夜精品福利在线| 欧美一区二区三区日韩视频| 欧美视频精品在线观看| 一区二区高清视频| 午夜精品久久久久久久99樱桃| 国产精品video| 午夜精彩视频在线观看不卡| 久久久不卡网国产精品一区| 极品尤物久久久av免费看| 久久嫩草精品久久久精品| 欧美aⅴ99久久黑人专区| 亚洲第一天堂av| 欧美激情在线播放| 中文av一区特黄| 久久久久久一区二区| 亚洲成人影音| 欧美日本三区| 亚洲一区欧美一区| 久久一区二区三区四区| **性色生活片久久毛片| 欧美激情按摩| 亚洲一区欧美一区| 噜噜爱69成人精品| 亚洲精品国产精品久久清纯直播| 欧美激情2020午夜免费观看| 亚洲视频在线二区| 欧美mv日韩mv亚洲| 亚洲一区二区在线免费观看| 国产一区二区三区不卡在线观看 | 欧美成人一区在线| 在线视频欧美日韩精品| 另类人畜视频在线| 一区二区三区四区五区视频| 国产手机视频一区二区| 欧美高清视频www夜色资源网| 亚洲天堂av综合网| 欧美激情bt| 欧美一区二区视频网站| 亚洲国产国产亚洲一二三| 国产精品视频内| 欧美国产先锋| 久久9热精品视频| 99精品国产99久久久久久福利| 久久国产精品久久久久久| 亚洲破处大片| 国产日韩欧美日韩| 欧美日韩在线播放一区| 欧美日韩视频在线一区二区观看视频| 亚洲国产精品嫩草影院| 欧美一区二区三区成人| 亚洲乱码久久| 狠狠色丁香婷综合久久| 欧美日韩中国免费专区在线看| 午夜视频在线观看一区| 99热在线精品观看| 女女同性女同一区二区三区91| 亚洲综合精品| 日韩一级在线| 91久久精品久久国产性色也91| 国产日韩欧美一区二区三区四区| 欧美精品v国产精品v日韩精品| 欧美在线综合视频| 亚洲欧美欧美一区二区三区| 9色国产精品|