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條評論
主站蜘蛛池模板: 成人黄色毛片 | 好吊在线视频 | 一级毛片卡 | 精品久久久久久久一区二区手机版 | 精品国产免费一区二区 | 亚洲精品中文字幕不卡在线 | 欧美精品亚洲精品日韩一区 | 热久久久久久 | 色综合天天综合网国产人 | 成年女人在线观看片免费视频 | 一本久道久久综合中文字幕 | 综合爱爱网 | 一级啪啪片 | 天天艹在线| 俄罗斯午夜影院 | 日韩欧美黄色大片 | 国产成人一区二区三区在线视频 | 久久午夜激情 | 国产日韩欧美亚洲综合首页 | 亚洲一区欧美日韩 | 国产成人精品视频频 | 91九色视频在线观看 | 欧洲国产伦久久久久久久 | 俄罗斯午夜影院 | 日本aaaa特级毛片 | 免费一看一级毛片人 | 久久99九九99九九99精品 | 日韩午夜在线视频 | 日韩精品成人 | 亚洲在线h| 国产综合视频 | 亚洲精品区在线播放一区二区 | 巴西一级毛片 | 中文字幕一区二区三 | 四虎影院免费看 | 久久加勒比| 天天拍夜夜添久久精品中文 | 香蕉97超级碰碰碰碰碰久 | 亚洲色吧| 国产欧美网站 | 6080欧美一区二区三区四区 |