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

Onway

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

之所以想到要注釋一下,沒別的意思,只是因為幾個月前剛學DP,完全看不懂,前幾天費了幾個小時終于看懂了,注釋下來,能使自己整理一下思路,也作為自己的一篇日記。

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

1,

我覺得理解那個優化函數,必須先要充分理解那個二維的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項(含第j項)的最大值。對于b[i][j]含有第j項必須要理解好!則方程的意思是:對于a[j]項,要么將它加到第i段,要么它自己作為新的一段。

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

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

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

2,

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

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

那么這時DP方程可以變為:

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

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

這里有一個關鍵是對c[]在計算第i段值b[j]的時候,要及時更新,以作計算下一段使用。

3,

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

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)項的最大值
    int *c=new int[n+1];    //c[j]保存的是i-1段中在i-1到j(含j)項中的最大值
                            
//注意,以上b[j]和c[j]都是指在計算第i段時的值;
    b[0]=0;
    c[
1]=0;                 //第0段時的兩個值,初始化邊界條件 
    for(int i=1;i<=m;i++)   //i為當前計算段數 
    {
        b[i]
=b[i-1]+a[i];    //b[i]即b[j]在j=i時的值,由于j=i,每一個項都要成為一段,這就是邊界條件
        c[i-1]=b[i];        //這里很繞,其實這句是沒用的,因為在第i段中數組c[]保存的值是為下一
                            
//段i+1服務的,i+1段只用到c[i],可以直接刪掉,免得誤導                        
        int max=b[i];        //max記錄第i段的從i位置開始所有能用到的項的最大值
        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位置的最大值,盡管當前循環中計算的是第j項
                max=b[j];        //更新max的值
        }
        c[i
+n-m]=max;    //由于max記錄的項總比循環的j項小1,所以第i段在最后一項中的最大值放在循環外更新
    }

    
int sum=0;        //默認全是負數的時候,最大值是0,如果要計算負的最大值,可以將sum設為一個大負數
    for(int j=m;j<=n;j++)    //為什么還有一次循環找最大值,而不是直接使用b[n]呢?因為b[j]包含了a[j],
        if(sum<b[j])        //在b[j]的值不一定比不包含a[j]的其他項大。
            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>
            国产精品福利在线观看网址| 久久久亚洲午夜电影| 欧美国产亚洲视频| 欧美一区二区视频在线观看2020| 亚洲欧洲一区二区三区| 久久不射中文字幕| 久久久福利视频| 久色成人在线| 蜜臀av一级做a爰片久久| 久久综合网hezyo| 欧美成人一区在线| 亚洲激情图片小说视频| 91久久精品一区二区三区| 亚洲精品国产精品国自产在线| 亚洲第一偷拍| 中国亚洲黄色| 欧美一区激情视频在线观看| 久久久久久夜| 久久蜜桃av一区精品变态类天堂| 久久国产视频网站| 欧美大片第1页| 一本色道久久88精品综合| 亚洲深夜福利视频| 久久久久久久综合狠狠综合| 欧美激情 亚洲a∨综合| 国产美女精品| 9人人澡人人爽人人精品| 欧美一级精品大片| 一区二区三区回区在观看免费视频| 狠狠久久综合婷婷不卡| 欧美精品久久99| 国内精品国产成人| 亚洲一区二区在线| 91久久精品国产91性色tv| 午夜精彩视频在线观看不卡| 欧美巨乳在线| 亚洲日本一区二区| 免费高清在线一区| 久久精品1区| 精品91在线| 美女精品国产| 免费成人美女女| 亚洲国产精品一区二区久| 久久在线免费观看| 久久一二三四| 最近中文字幕日韩精品| 亚洲丰满在线| 欧美精品激情blacked18| 91久久久亚洲精品| 最新中文字幕一区二区三区| 欧美日韩国产在线播放| 午夜精品久久久久久久久久久久久| 亚洲高清久久| 日韩一级黄色片| 国产原创一区二区| 欧美岛国在线观看| 欧美精品电影在线| 欧美在线www| 欧美日韩一级大片网址| 久久久久久亚洲精品中文字幕| 久热精品在线视频| 一区二区三区**美女毛片| 亚洲一区二区不卡免费| 亚洲美女色禁图| 久久精品女人的天堂av| 亚洲午夜久久久久久久久电影院 | 亚洲欧美日韩国产中文在线| 亚洲欧美成人一区二区在线电影| 国内欧美视频一区二区| 亚洲精品激情| 91久久黄色| 久久精彩视频| 蜜臀久久久99精品久久久久久| 国产精品久久久久久久久久免费看| 美女91精品| 亚洲国产成人精品女人久久久 | 91久久国产精品91久久性色| 国产精品日韩精品欧美在线| 亚洲第一视频网站| 亚洲看片免费| 欧美激情中文不卡| 亚洲精品一区二区三区四区高清| 国产精品一级久久久| 亚洲美女黄色片| 亚洲一区在线免费观看| 久久动漫亚洲| 久久成人免费电影| 噜噜噜91成人网| 亚洲精品欧美| 欧美日韩中文在线| 亚洲欧美久久久| 亚洲成色777777在线观看影院| 亚洲国产岛国毛片在线| 欧美精品一卡| 欧美在线视频二区| 欧美寡妇偷汉性猛交| 亚洲特色特黄| 在线日韩一区二区| 欧美午夜视频网站| 久久精品最新地址| 亚洲国产成人在线视频| 亚洲免费视频网站| 亚洲黄色一区| 狠狠色狠狠色综合系列| 欧美激情亚洲另类| 久久久久99| 午夜精品在线| 亚洲与欧洲av电影| 亚洲欧洲精品一区二区三区波多野1战4 | 欧美高清视频www夜色资源网| 91久久精品国产91性色tv| 另类亚洲自拍| 麻豆精品在线视频| 久久久久免费视频| 欧美一区二区视频在线观看| 亚洲欧美日本在线| 欧美高清在线一区二区| 久久精品国亚洲| 性欧美8khd高清极品| 亚洲一区二区免费| 亚洲制服欧美中文字幕中文字幕| 精品粉嫩aⅴ一区二区三区四区| 欧美三级不卡| 欧美色综合天天久久综合精品| 欧美另类变人与禽xxxxx| 亚洲午夜一区二区| 亚洲自拍偷拍麻豆| 亚洲欧美日韩一区在线| 亚洲资源av| 久久久噜噜噜久久中文字幕色伊伊 | 亚洲福利免费| 今天的高清视频免费播放成人 | 亚洲永久在线观看| 午夜精品一区二区三区四区| 亚洲一区二区三区欧美| 亚洲影音一区| 免费一区视频| 亚洲免费观看高清在线观看| 亚洲在线观看| 欧美激情一区二区| 国产精品入口| 一区二区高清视频在线观看| 欧美主播一区二区三区| 在线不卡中文字幕| 在线日韩中文| 午夜亚洲视频| 亚洲电影免费观看高清完整版在线观看| 亚洲激情视频网站| 欧美超级免费视 在线| 欧美国产视频日韩| 亚洲伊人伊色伊影伊综合网| 欧美电影免费网站| 国产精品热久久久久夜色精品三区| 影院欧美亚洲| 久久久久综合网| 久久久福利视频| 国内精品一区二区三区| 欧美一级专区| 久久激情综合网| 亚洲缚视频在线观看| 免费成人小视频| 欧美日韩视频不卡| 亚洲一区二区三区久久 | 亚洲视频日本| 亚洲天堂av电影| 国产精品毛片va一区二区三区| 一区二区三区四区五区精品| 国内精品久久久久伊人av| 久久久999精品| 欧美高清影院| 欧美影视一区| 欧美成人在线网站| 午夜日韩在线| 久久中文精品| 亚洲一区二区三区精品在线观看 | 久久精品国产成人| 欧美金8天国| 久久国产一区二区三区| 久久一综合视频| 亚洲图片欧洲图片av| 久久riav二区三区| 亚洲一区二区少妇| 欧美成人午夜激情视频| 欧美亚洲网站| 欧美精品日韩一区| 欧美不卡视频一区| 好看不卡的中文字幕| 亚洲视频免费在线观看| 一本大道av伊人久久综合| 欧美在线视频网站| 欧美性一二三区| 欧美不卡视频一区| 狠狠色丁香婷综合久久| 午夜国产不卡在线观看视频| 亚洲一区二区三区激情| 欧美体内谢she精2性欧美| 91久久精品美女| 一区二区久久久久久| 久久久久久久精| 欧美jjzz|