• <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>
            xiaoguozi's Blog
            Pay it forword - 我并不覺的自豪,我所嘗試的事情都失敗了······習慣原本生活的人不容易改變,就算現狀很糟,他們也很難改變,在過程中,他們還是放棄了······他們一放棄,大家就都是輸家······讓愛傳出去,很困難,也無法預料,人們需要更細心的觀察別人,要隨時注意才能保護別人,因為他們未必知道自己要什么·····
            http://acm.pku.edu.cn/JudgeOnline/problem?id=3670
             1 #include <iostream>
             2 #include <vector>
             3 
             4 using namespace std;
             5 const int N=30005;
             6 int dp1[N];
             7 int dp2[N];
             8 int dp3[N];
             9 int d1[N];
            10 int d2[N];
            11 int main()
            12 {
            13     int n;
            14     while(cin>>n){
            15         int num;
            16         memset(dp1,0,sizeof(dp1));
            17         memset(dp2,0,sizeof(dp2));
            18         memset(dp3,0,sizeof(dp3));
            19         for(int i=0;i<n;i++){
            20             cin>>d1[i];
            21             d2[n-i-1]=d1[i];
            22         }
            23         switch(d1[0]){
            24             case 1:
            25                 dp1[0]=0,dp2[0]=1,dp3[0]=1;
            26                 break;
            27             case 2:
            28                 dp1[0]=1,dp2[0]=0,dp3[0]=1;
            29                 break;
            30             case 3:
            31                 dp1[0]=1,dp2[0]=1,dp3[0]=0;
            32                 break;
            33         }
            34 
            35         for(int i=1;i<n;i++){
            36             switch(d1[i]){
            37                 case 1:
            38                     dp1[i]=dp1[i-1];
            39                     dp2[i]=min(dp1[i-1],dp2[i-1])+1;
            40                     dp3[i]=min(dp1[i-1],min(dp2[i-1],dp3[i-1]))+1;
            41                     break;
            42                 case 2:
            43                     dp1[i]=dp1[i-1]+1;
            44                     dp2[i]=min(dp1[i-1],dp2[i-1]);
            45                     dp3[i]=min(dp1[i-1],min(dp2[i-1],dp3[i-1]))+1;
            46                     break;
            47                 case 3:
            48                     dp1[i]=dp1[i-1]+1;
            49                     dp2[i]=min(dp1[i-1],dp2[i-1])+1;
            50                     dp3[i]=min(dp1[i-1],min(dp2[i-1],dp3[i-1]));
            51                     break;
            52             }
            53         }
            54         int ans=0x7fffffff;
            55         if(ans>dp1[n-1])ans=dp1[n-1];
            56         if(ans>dp2[n-1])ans=dp2[n-1];
            57         if(ans>dp3[n-1])ans=dp3[n-1];
            58 
            59         switch(d2[0]){
            60             case 1:
            61                 dp1[0]=0,dp2[0]=1,dp3[0]=1;
            62                 break;
            63             case 2:
            64                 dp1[0]=1,dp2[0]=0,dp3[0]=1;
            65                 break;
            66             case 3:
            67                 dp1[0]=1,dp2[0]=1,dp3[0]=0;
            68                 break;
            69         }
            70 
            71         for(int i=1;i<n;i++){
            72             switch(d2[i]){
            73                 case 1:
            74                     dp1[i]=dp1[i-1];
            75                     dp2[i]=min(dp1[i-1],dp2[i-1])+1;
            76                     dp3[i]=min(dp1[i-1],min(dp2[i-1],dp3[i-1]))+1;
            77                     break;
            78                 case 2:
            79                     dp1[i]=dp1[i-1]+1;
            80                     dp2[i]=min(dp1[i-1],dp2[i-1]);
            81                     dp3[i]=min(dp1[i-1],min(dp2[i-1],dp3[i-1]))+1;
            82                     break;
            83                 case 3:
            84                     dp1[i]=dp1[i-1]+1;
            85                     dp2[i]=min(dp1[i-1],dp2[i-1])+1;
            86                     dp3[i]=min(dp1[i-1],min(dp2[i-1],dp3[i-1]));
            87                     break;
            88             }
            89         }
            90 
            91         if(ans>dp1[n-1])ans=dp1[n-1];
            92         if(ans>dp2[n-1])ans=dp2[n-1];
            93         if(ans>dp3[n-1])ans=dp3[n-1];
            94 
            95         cout<<ans<<endl;
            96     }
            97     return 0;
            98 }
            99 
            posted on 2008-07-25 15:27 小果子 閱讀(216) 評論(0)  編輯 收藏 引用
            日本道色综合久久影院| 亚洲中文字幕久久精品无码APP | 久久久久国产| 99久久精品国产一区二区| 成人国内精品久久久久影院| 天天综合久久一二三区| MM131亚洲国产美女久久| 色婷婷久久久SWAG精品| 精品国产91久久久久久久| 久久人人爽人人爽人人片AV不| 成人久久精品一区二区三区| 欧美亚洲国产精品久久高清| 久久国产精品偷99| 九九久久99综合一区二区| 亚洲AV无码久久精品狠狠爱浪潮| 久久国产成人午夜AV影院| 久久99免费视频| 久久亚洲私人国产精品| 久久AV高潮AV无码AV| 欧美粉嫩小泬久久久久久久| 国产精品日韩欧美久久综合| 国产精品久久久久AV福利动漫| 久久久www免费人成精品| 2021久久精品免费观看| 久久中文精品无码中文字幕| 精品视频久久久久| 欧美久久一级内射wwwwww.| 国产69精品久久久久99尤物| 国产成人无码精品久久久免费| 青青草国产精品久久久久| 久久被窝电影亚洲爽爽爽| 久久99久久99小草精品免视看| 69久久精品无码一区二区| 国产∨亚洲V天堂无码久久久| 久久久久国产精品熟女影院| 亚洲AV无码成人网站久久精品大| 久久水蜜桃亚洲av无码精品麻豆| 久久中文骚妇内射| 国产精品狼人久久久久影院| 欧美激情精品久久久久久久| 久久久网中文字幕|