2#include3charnum[85];4intdp[85],n;5booljudge(intst1" />

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

POJ 1239 Increasing Sequences [DP]

系統(tǒng) 2025 0

題意:略。

思路:進行兩次dp。

第一次dp從前向后,用dp[x]表示從第x位向前dp[x]位可構(gòu)成一個數(shù)字,且與前面的數(shù)組符合題意要求。最后求的dp[n]即為最后一個數(shù)字的長度。

而題目還有要求,所有解中輸出前面數(shù)字最大的一個。因此還需要進行一次dp,從后向前。

具體看代碼吧,當(dāng)初也是看別人代碼才看懂的。

?

      
         1
      
       #include<stdio.h>


      
         2
      
       #include<
      
        string
      
      .h>


      
         3
      
      
        char
      
       num[
      
        85
      
      
        ];


      
      
         4
      
      
        int
      
       dp[
      
        85
      
      
        ], n;


      
      
         5
      
      
        bool
      
       judge(
      
        int
      
       st1,
      
        int
      
       len1,
      
        int
      
       st2,
      
        int
      
      
         len2)


      
      
         6
      
      
        {


      
      
         7
      
      
        while
      
       (num[st1] == 
      
        '
      
      
        0
      
      
        '
      
       && len1) st1++, len1--
      
        ;


      
      
         8
      
      
        while
      
       (num[st2] == 
      
        '
      
      
        0
      
      
        '
      
       && len2) st2++, len2--
      
        ;


      
      
         9
      
      
        if
      
       (len1 < len2) 
      
        return
      
      
        1
      
      
        ;


      
      
        10
      
      
        else
      
      
        if
      
       (len1 > len2) 
      
        return
      
      
        0
      
      
        ;


      
      
        11
      
      
        else
      
      
        12
      
      
            {


      
      
        13
      
      
        for
      
       (
      
        int
      
       i = 
      
        0
      
      ; i < len1; i++
      
        )


      
      
        14
      
      
                {


      
      
        15
      
      
        if
      
       (num[st1+i] < num[st2+i]) 
      
        return
      
      
        1
      
      
        ;


      
      
        16
      
      
        if
      
       (num[st1+i] > num[st2+i]) 
      
        return
      
      
        0
      
      
        ;


      
      
        17
      
      
                }


      
      
        18
      
      
            }


      
      
        19
      
      
        return
      
      
        0
      
      
        ;


      
      
        20
      
      
        }


      
      
        21
      
      
        void
      
       print(
      
        int
      
      
         pos)


      
      
        22
      
      
        {


      
      
        23
      
      
        if
      
       (pos > n) 
      
        return
      
      
        ;


      
      
        24
      
      
        if
      
       (pos != 
      
        1
      
      ) printf(
      
        "
      
      
        ,
      
      
        "
      
      
        );


      
      
        25
      
      
        for
      
       (
      
        int
      
       i = pos; i < pos + dp[pos]; i++
      
        )


      
      
        26
      
               printf(
      
        "
      
      
        %c
      
      
        "
      
      
        , num[i]);


      
      
        27
      
           print(pos +
      
         dp[pos]);


      
      
        28
      
      
        }


      
      
        29
      
      
        int
      
      
         main()


      
      
        30
      
      
        {


      
      
        31
      
      
        while
      
       (~scanf(
      
        "
      
      
        %s
      
      
        "
      
      , num + 
      
        1
      
      ) && strcmp(num + 
      
        1
      
      , 
      
        "
      
      
        0
      
      
        "
      
      
        ))


      
      
        32
      
      
            {


      
      
        33
      
               n = strlen(num + 
      
        1
      
      
        );


      
      
        34
      
               dp[
      
        1
      
      ] = 
      
        1
      
      
        ;


      
      
        35
      
      
        for
      
       (
      
        int
      
       i = 
      
        2
      
      ; i <= n; i++
      
        )


      
      
        36
      
      
                {


      
      
        37
      
                   dp[i] =
      
         i;


      
      
        38
      
      
        for
      
       (
      
        int
      
       j = i - 
      
        1
      
      ; j >= 
      
        1
      
      ; j--
      
        )


      
      
        39
      
      
        if
      
       (judge(j - dp[j] + 
      
        1
      
      , dp[j], j + 
      
        1
      
      , i -
      
         j))


      
      
        40
      
      
                        {


      
      
        41
      
                           dp[i] = i -
      
         j;


      
      
        42
      
      
        break
      
      
        ;


      
      
        43
      
      
                        }


      
      
        44
      
      
                }


      
      
        45
      
      
        int
      
       pos = n - dp[n] + 
      
        1
      
      
        ;


      
      
        46
      
               dp[pos] =
      
         dp[n];


      
      
        47
      
      
        for
      
       (
      
        int
      
       i = pos - 
      
        1
      
      ; i >= 
      
        1
      
      ; i--
      
        )


      
      
        48
      
      
                {


      
      
        49
      
      
        if
      
       (num[i] == 
      
        '
      
      
        0
      
      
        '
      
      
        )


      
      
        50
      
      
                    {


      
      
        51
      
                       dp[i] = dp[i+
      
        1
      
      ] + 
      
        1
      
      
        ;


      
      
        52
      
      
        continue
      
      
        ;


      
      
        53
      
      
                    }


      
      
        54
      
      
        for
      
       (
      
        int
      
       j = pos; j > i; j--
      
        )


      
      
        55
      
      
        if
      
       (judge(i, j -
      
         i, j, dp[j]))


      
      
        56
      
      
                        {


      
      
        57
      
                           dp[i] = j -
      
         i;


      
      
        58
      
      
        break
      
      
        ;


      
      
        59
      
      
                        }


      
      
        60
      
      
                }


      
      
        61
      
               print(
      
        1
      
      
        );


      
      
        62
      
               printf(
      
        "
      
      
        \n
      
      
        "
      
      
        );


      
      
        63
      
      
            }


      
      
        64
      
      
        return
      
      
        0
      
      
        ;


      
      
        65
      
       }
    

?

?

?

POJ 1239 Increasing Sequences [DP]


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

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號聯(lián)系: 360901061

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

【本文對您有幫助就好】

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

發(fā)表我的評論
最新評論 總共0條評論
主站蜘蛛池模板: 亚洲精品国产美女在线观看 | 中文在线观看视频 | 特黄女一级毛片 | 欧美特黄a级猛片a级 | 香港a毛片免费全部播放 | 伊人久色 | 欧美xxxwww | 日韩欧美在线看 | 欧美另类网站 | 国产aaa级一级毛片 国产aaa毛片 | 国产免费无遮挡精品视频 | 日韩视频一区二区在线观看 | 四虎在线免费 | 亚洲v在线 | 欧美人牲囗毛片 | 成人a毛片 | 欧美一区二区三区黄色 | 99热这里只有精品在线播放 | 黄色毛片视频免费 | 夜夜天天操 | 久久88色综合色鬼 | 免费看成人频视在线视频 | 青青草一区二区免费精品 | 亚洲一级毛片在线播放 | 婷婷综合激情五月中文字幕 | 四虎影院大全 | 亚洲另类视频在线观看 | 裸身裸乳免费视频网站 | 国产高清在线91福利 | 精品久久网 | 国产日产久久高清欧美一区 | 久久亚洲国产欧洲精品一 | 亚洲日产综合欧美一区二区 | 亚洲综合狠狠 | 一级毛片免费视频 | 中文一级片 | 牛牛影院成人网 | 亚洲欧美精品综合中文字幕 | 国产啪爱视频精品免视 | 黄色毛片一级 | 337p日本大胆欧美人术艺术6 |