• <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>

            Dain

            寫出一個(gè)可以工作的程序并不夠

            統(tǒng)計(jì)

            留言簿(3)

            積分與排名

            良師益友

            閱讀排行榜

            評(píng)論排行榜

            最大的子序列和問題

            求解該問題的四種算法:
            時(shí)間O(N3),算法一
            int ?MaxSubsequenceSum( const ? int ?A[], int ?N)
            {
            ????
            int
            ?ThisSum,MaxSum,i,j,k;
            ????
            ????MaxSum?
            = ? 0
            ;
            ????
            for (i? = ? 0 ;i? < ?N;i ++
            )
            ????????
            for (j? = ?i;j? < ?N;j ++
            )
            ????????
            {
            ????????????ThisSum?
            = ? 0
            ;
            ????????????
            for (k? = ?i;k? <= ?j;k ++ )????ThisSum? +=
            ?A[k];????????????????
            ????????????
            if (ThisSum? > ?MaxSum)????MaxSum? =
            ?ThisSum;
            ????????}

            ????????
            ????
            return ?MaxSum;
            }
            時(shí)間O(N2),算法二
            int ?MaxSubsequenceSum( const ? int ?A[], int ?N)
            {
            ????
            int
            ?ThisSum,MaxSum,i,j;
            ????
            ????MaxSum?
            = ? 0
            ;
            ????
            for (i? = ? 0 ;i? < ?N;i ++
            )
            ????
            {
            ????????ThisSum?
            = ? 0
            ;
            ????????
            for (j? = ?i;j? < ?N;j ++
            )
            ????????
            {
            ????????????ThisSum?
            +=
            ?A[k];????????????????
            ????????????
            if (ThisSum? > ?MaxSum)????MaxSum? =
            ?ThisSum;
            ????????}

            ????}

            ????????
            ????
            return ?MaxSum;
            }
            時(shí)間O(NlogN),算法三
            static ? int ?MaxSubSum( const ? int ?A[], int ?Left, int ?Right)
            {
            ????
            int
            ?MaxLeftSum,MaxRightSum;
            ????
            int
            ?MaxLeftBorderSum,MaxRightBorderSum;
            ????
            int
            ?LeftBorderSum,RightBorderSum;
            ????
            int
            ?Center,i;
            ????
            ????
            if (Left? ==
            ?Right)
            ????????
            if (A[left]? > ? 0 )???? return
            ?A[left];
            ????????
            else ???? return ? 0
            ;
            ????????????
            ????Center?
            = ?(Left? + ?Right)? / ? 2
            ;
            ????MaxLeftSum?
            =
            ?MaxSubSum(A,Left,Center);
            ????MaxRightSum?
            = ?MaxSubSum(A,Center? + ? 1
            ,Right);
            ????
            ????MaxLeftBorderSum?
            = ? 0
            ;
            ????LeftBorderSum?
            = ? 0
            ;
            ????
            for (i? = ?Center;i? >= ?Left;i --
            )
            ????
            {
            ????????LeftBorderSum?
            +=
            ?A[i];
            ????????
            if (LeftBorderSum? > ?MaxLeftBorderSum)????MaxLeftBorderSum? =
            ?LeftBorderSum;
            ????}

            ????
            ????MaxRightBorderSum?
            = ? 0 ;
            ????RightBorderSum?
            = ? 0
            ;
            ????
            for (i? = ?Center? + ? 1 ;i? <= ?Right;i ++
            )
            ????
            {
            ????????RightBorderSum?
            +=
            ?A[i];
            ????????
            if (RightBorderSum? > ?MaxRightBorderSum)????MaxRightBorderSum? =
            ?RightBorderSum;
            ????}

            ????
            ????
            return ?Max3(MaxLeftSum,MaxRightSum,MaxLeftBorderSum? + ?MaxRightBorderSum);
            }


            int ?MaxSubsequenceSum( const int??A[],int ?N)
            {
            ????
            return ?MaxSubSum(A, 0 ,N? - ? 1
            );????
            }
            時(shí)間O(N),算法四
            intMaxSubsequenceSum( const int ?A[], int ?N)
            {
            ????
            int ?ThisSum,MaxSum,i;
            ????
            ????ThisSum?
            = ?MaxSum? = ? 0 ;
            ????
            for (i? = ? 0 ;i? < ?N;i ++ )
            ????
            {
            ????????ThisSum?
            += ?A[i];
            ????????
            if (ThisSum? > ?MaxSum)
            ????????????MaxSum?
            = ?ThisSum;
            ????????
            else
            ????????????ThisSum?
            = ? 0 ;
            ????}

            ????
            ????
            return ?MaxSum;
            }


            參考《數(shù)據(jù)結(jié)構(gòu)與算法分析》

            posted on 2007-02-07 10:52 Dain 閱讀(1065) 評(píng)論(7)  編輯 收藏 引用 所屬分類: 算法筆記

            評(píng)論

            # re: 最大的子序列和問題[未登錄] 2007-02-08 01:36

            呵呵, dp是王道  回復(fù)  更多評(píng)論   

            # re: 最大的子序列和問題 2007-02-08 16:53 Dain

            嗯,dp
            對(duì)于這個(gè)問題,算法三和四都是不錯(cuò)的思路@豪
              回復(fù)  更多評(píng)論   

            # re: 最大的子序列和問題 2007-02-09 16:24 alai04

            樓主開什么玩笑,算法四明顯是不對(duì)的嘛,是考一下我們的眼力嗎?  回復(fù)  更多評(píng)論   

            # re: 最大的子序列和問題 2007-03-25 20:50 felix

            四不對(duì)
            如:
            1 5 -3 2 4
              回復(fù)  更多評(píng)論   

            # re: 最大的子序列和問題 2007-03-25 20:51 felix

            三用的是分治,不是DP吧?  回復(fù)  更多評(píng)論   

            # re: 最大的子序列和問題 2007-03-30 11:12 dqchen

            第四個(gè)
            MaxSum = -((static_cast<unsigned int>(~0)) >> 1) - 1;

            ThisSum = 0;
            for (int i = 0;i < A.size();i++)
            {
            ThisSum += A[i];
            if(ThisSum > MaxSum)
            MaxSum = ThisSum;
            else
            ThisSum = 0;
            }
              回復(fù)  更多評(píng)論   

            # 第四個(gè)算法的實(shí)現(xiàn)是錯(cuò)誤的 2008-07-04 17:53 wetwoo

            輸入如下:-2 11 -4 13 -5 -2
            輸出如下:13
            正確輸出應(yīng)該為:20
            修改如下:
            intMaxSubsequenceSum( const int A[], int N)
            {
            int ThisSum,MaxSum,i;

            ThisSum = MaxSum = 0 ;
            for (i = 0 ;i < N;i ++ )
            {
            ThisSum += A[i];
            if (ThisSum > MaxSum)
            MaxSum = ThisSum;
            else if(ThisSum < 0)
            ThisSum = 0 ;
            }

            return MaxSum;
            }   回復(fù)  更多評(píng)論   

            久久99国产精品久久99| 精品久久久久久久久久久久久久久| av色综合久久天堂av色综合在 | 久久偷看各类wc女厕嘘嘘| 久久精品国产精品亚洲人人| 狠狠色丁香久久婷婷综合五月| 蜜桃麻豆WWW久久囤产精品| 香港aa三级久久三级老师2021国产三级精品三级在 | 1000部精品久久久久久久久| 人妻无码中文久久久久专区| 91精品国产91久久久久久| 亚洲欧美日韩精品久久| 99久久免费国产精品特黄| 久久香蕉一级毛片| 国产午夜精品久久久久九九电影 | 日本精品久久久久影院日本| 久久人妻少妇嫩草AV无码专区| 亚洲国产另类久久久精品黑人 | 久久亚洲精品成人AV| 精品久久久久久无码中文字幕 | 777午夜精品久久av蜜臀| 精品免费久久久久国产一区 | 久久精品这里只有精99品| 久久超碰97人人做人人爱| 亚洲国产精品无码久久久久久曰| 色诱久久av| 88久久精品无码一区二区毛片| 色偷偷久久一区二区三区| 久久亚洲av无码精品浪潮| 亚洲中文字幕无码久久综合网| 久久国产精品波多野结衣AV| 久久精品99久久香蕉国产色戒| 狠狠色丁香久久婷婷综合蜜芽五月| 久久国产成人精品国产成人亚洲| 亚洲国产精品久久| 久久综合九色综合久99| 久久亚洲国产午夜精品理论片 | 思思久久99热只有频精品66| 久久精品九九亚洲精品| 久久精品国产精品亚洲精品| 国产一级做a爰片久久毛片|