亚洲免费在线-亚洲免费在线播放-亚洲免费在线观看-亚洲免费在线观看视频-亚洲免费在线看-亚洲免费在线视频

Hdu 5064 Find Sequence 解題報(bào)告

系統(tǒng) 1876 0

?

題目出處: http://acm.hdu.edu.cn/showproblem.php?pid=5064

題意: 給定n個(gè)數(shù),求滿足以下兩個(gè)條件的子序列的最大長(zhǎng)度:

  (1)C 1 <C 2 <C 3 <......<C t ;

  (2)C 2 -C 1 <C 3 -C 2 <......<C t -C t-1 .

?

分析: 解結(jié)構(gòu)一定為為N 1 ,N 1 ,N 1 ,......,N 1 ,N 2 ,N 3 ,......,N t ?

   ??設(shè)dp[i][j]表示以num[i], num[j]結(jié)尾的有效序列的長(zhǎng)度,則有
? ? ? ? ?dp[i][j] = max(dp[k][i]+ 1) ,,,,,,,k<=i且num[i]-num[k]<=num[j]-num[i]

   ? 剪枝一:
? ? ? ? ? ? ?考慮非遞減序列 num[s],num[k],num[i],num[j] ,num[e],
? ? ? ? ? ? ?容易得到 dp[s][i]<=dp[s][i] (例如1,2,3) 即右端點(diǎn)固定 左端點(diǎn)越遠(yuǎn)越小,
? ? ? ? ? ? ?同時(shí)因?yàn)樾蛄袕男〉酱笈帕校虼?左端點(diǎn)越遠(yuǎn)num[i]-num[k]越大,
? ? ? ? ? ? ?所以,對(duì)于算某一特定的dp[i][j]時(shí)num[j]-num[i]是一個(gè)定值從k=i開始遞減遍歷dp[k][i]+ 1 取最大值,待條件不滿足時(shí)跳出循環(huán)。


? ? ? ? 剪枝二:
? ? ? ? ? ? ?因?yàn)?若num[i]-num[k]<=num[j]-num[i]成立 則num[i]-num[k]<=num[j+1]-num[i]必成立,
? ? ? ? ? ? ?即 dp[i][j]<=dp[i][j+1] (例如 1(num[k]),4(num[i]),5(num[j]),8(num[j+1]))
? ? ? ? ? ? ?即 左端點(diǎn)固定 小區(qū)間能取到的序列 大區(qū)間一定可以取到,
? ? ? ? ? ? ?所以,每次計(jì)算新的dp[i][j]時(shí)k只要在上次的基礎(chǔ)上繼續(xù)向左遍歷dp[k][i]+ 1,取最大值即可。

?

源代碼:

      
         1
      
       #include<cstdio>


      
         2
      
       #include<iostream>


      
         3
      
       #include<map>


      
         4
      
      
        using
      
      
        namespace
      
      
         std;


      
      
         5
      
      
        int
      
       n,M,num[
      
        3000
      
      ],cnt[
      
        3000
      
      ],size,dp[
      
        3000
      
      ][
      
        3000
      
      
        ];


      
      
         6
      
      
         7
      
      
        int
      
       maxVal(
      
        int
      
       a,
      
        int
      
       b){
      
        return
      
       a>b?
      
        a:b;}


      
      
         8
      
      
         9
      
      
        int
      
      
         main() 


      
      
        10
      
      
        {


      
      
        11
      
      
        int
      
      
         t;


      
      
        12
      
           scanf(
      
        "
      
      
        %d
      
      
        "
      
      ,&
      
        t);


      
      
        13
      
      
        while
      
      (t--
      
        )


      
      
        14
      
      
            {


      
      
        15
      
               scanf(
      
        "
      
      
        %d%d
      
      
        "
      
      ,&n,&
      
        M);


      
      
        16
      
      
        int
      
      
         i,j,k;


      
      
        17
      
               size = 
      
        0
      
      ;
      
        //
      
      
        序列中有size個(gè)不同的數(shù)
      
      
        18
      
               map<
      
        int
      
      ,
      
        int
      
      >
      
         mp;


      
      
        19
      
               map<
      
        int
      
      ,
      
        int
      
      >
      
        ::iterator it;


      
      
        20
      
      
        //
      
      
        記錄序列中某個(gè)數(shù)i出現(xiàn)了幾次, 
      
      
        21
      
      
        for
      
      (i=
      
        0
      
      ;i<n;i++
      
        )


      
      
        22
      
      
                {


      
      
        23
      
      
        int
      
      
         a;


      
      
        24
      
                   scanf(
      
        "
      
      
        %d
      
      
        "
      
      ,&
      
        a);


      
      
        25
      
                   mp[a]++
      
        ;


      
      
        26
      
      
                }


      
      
        27
      
      
        //
      
      
        用map是可以默認(rèn)取數(shù)據(jù)時(shí)從小到大


      
      
        28
      
      
        //
      
      
        PS:網(wǎng)絡(luò)上不用map用數(shù)組預(yù)先處理的執(zhí)行時(shí)間約600MS,用map約200MS
      
      
        29
      
      
        for
      
      (it=mp.begin(); it!=mp.end();it++
      
        )


      
      
        30
      
      
                {


      
      
        31
      
                   num[size] = it->
      
        first;


      
      
        32
      
                   cnt[size] = it->
      
        second;


      
      
        33
      
                   size++
      
        ;


      
      
        34
      
      
                }


      
      
        35
      
      
        36
      
      
        int
      
       res = 
      
        1
      
      
        ;


      
      
        37
      
      
        for
      
      (i=
      
        0
      
      ;i<size;i++
      
        )


      
      
        38
      
      
                {


      
      
        39
      
                   dp[i][i] =
      
         cnt[i];


      
      
        40
      
                   res =
      
        maxVal(res, dp[i][i]);


      
      
        41
      
                   k=
      
        i;


      
      
        42
      
      
        int
      
       temp = -
      
        1
      
      
        ;


      
      
        43
      
      
        for
      
      (j=i+
      
        1
      
      ;j<size;j++
      
        )


      
      
        44
      
      
                    {


      
      
        45
      
      
        for
      
      (;k>=
      
        0
      
      ;k--
      
        )


      
      
        46
      
      
                        {


      
      
        47
      
      
        if
      
      (num[i]-num[k]<=num[j]-
      
        num[i])


      
      
        48
      
      
                            {


      
      
        49
      
                               temp = maxVal(dp[k][i] + 
      
        1
      
      
        ,temp);


      
      
        50
      
      
                            }


      
      
        51
      
      
        else
      
      
        52
      
      
                            {


      
      
        53
      
      
        break
      
      
        ;


      
      
        54
      
      
                            }


      
      
        55
      
      
                        }


      
      
        56
      
                       dp[i][j] =
      
         temp;


      
      
        57
      
                       res =
      
        maxVal(res, dp[i][j]);


      
      
        58
      
      
                    }


      
      
        59
      
      
                }


      
      
        60
      
               printf(
      
        "
      
      
        %d\n
      
      
        "
      
      
        ,res);


      
      
        61
      
      
        62
      
      
            }


      
      
        63
      
      
        return
      
      
        0
      
      
        ;


      
      
        64
      
       }
    

?

Hdu 5064 Find Sequence 解題報(bào)告


更多文章、技術(shù)交流、商務(wù)合作、聯(lián)系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號(hào)聯(lián)系: 360901061

您的支持是博主寫作最大的動(dòng)力,如果您喜歡我的文章,感覺我的文章對(duì)您有幫助,請(qǐng)用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點(diǎn)擊下面給點(diǎn)支持吧,站長(zhǎng)非常感激您!手機(jī)微信長(zhǎng)按不能支付解決辦法:請(qǐng)將微信支付二維碼保存到相冊(cè),切換到微信,然后點(diǎn)擊微信右上角掃一掃功能,選擇支付二維碼完成支付。

【本文對(duì)您有幫助就好】

您的支持是博主寫作最大的動(dòng)力,如果您喜歡我的文章,感覺我的文章對(duì)您有幫助,請(qǐng)用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長(zhǎng)會(huì)非常 感謝您的哦!!!

發(fā)表我的評(píng)論
最新評(píng)論 總共0條評(píng)論
主站蜘蛛池模板: 亚洲人成自拍网站在线观看忄 | 性久久| 老师粗又长好猛好爽视频 | 中文字幕一区二区三区精品 | 欧美三级纯黄版 | 成人免费视频网 | 久久精品在线 | 国产99精品免费视频看6 | 欧洲一级黄色片 | 亚洲综合精品一区二区三区中文 | 91精品欧美成人 | 一区二区免费在线观看 | 一区二区三区视频网站 | 国产在线成人精品 | 日韩久久免费视频 | 2019最新四虎免费8848 | 国产精品久久久久久久 | 国产精品久久久久久久久久久久 | 日韩精品午夜视频一区二区三区 | 亚洲一区二区三区一品精 | 两性视频久久 | 国产精品免费观看 | 久久久久亚洲精品一区二区三区 | 色综合色狠狠天天综合色 | 国产精品看片 | 欧美三级午夜理伦三级小说 | 国产成人精品视频播放 | 久草久草久草 | chinese国产一区二区 | 久久婷婷综合在线视频观看6 | 成人久久影院 | 久久久久久九 | 中文一级毛片 | 亚洲欧美日韩精品久久 | 日韩爱爱小视频 | 久久99国产精品久久欧美 | 在线综合视频 | 99热这里有免费国产精品 | 91尤物国产尤物福利 | 99色在线 | 99视频网站 |