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

            糯米

            TI DaVinci, gstreamer, ffmpeg
            隨筆 - 167, 文章 - 0, 評(píng)論 - 47, 引用 - 0
            數(shù)據(jù)加載中……

            POJ 1989 The Cow Lineup 動(dòng)態(tài)規(guī)劃

            思路:
            如果之前出現(xiàn)過長度為 len 的子序列。假設(shè)該子序列出現(xiàn)在 [a, b] 之間。
            那如果存在 1, 2, ... K 任意一個(gè)數(shù)字出現(xiàn)在 [a, b] 之間,則必然存在一個(gè)長度為 len + 1 的非子序列。

            代碼:
            從后往前推。用的是鏈表。94ms AC。
            速度一般,還是不知道那些 0ms 是怎么搞出來的。
            有人說可以從前往后推,可能會(huì)快一點(diǎn)吧。

            #include <stdio.h>

            #define MAX_N 100032
            #define MAX_K 10032

            struct node {
                
            int idx;
                
            struct node *next;
            }
            ;
            struct node nodes[MAX_N], *pos[MAX_K];
            int N, K, left;

            int main()
            {
                
            int i, j, len;

                freopen(
            "e:\\test\\in.txt""r", stdin);
                
                scanf(
            "%d%d"&N, &K);
                
            for (i = 0; i < N; i++{
                    scanf(
            "%d"&j);
                    nodes[i].idx 
            = i;
                    nodes[i].next 
            = pos[j];
                    pos[j] 
            = &nodes[i];
                }


                left 
            = N + 1;
                
            for (len = 1; len <= N; len++{
                    j 
            = left;
                    
            for (i = 1; i <= K; i++{
                        
            while (pos[i] && pos[i]->idx >= left)
                            pos[i] 
            = pos[i]->next;
                        
            if (!pos[i])
                            
            break;
                        
            if (pos[i]->idx < j)
                            j 
            = pos[i]->idx;
                    }

                    
            if (i <= K)
                        
            break;
                    left 
            = j;
                }

                printf(
            "%d\n", len);

                
            return 0;
            }

            posted on 2010-03-14 15:46 糯米 閱讀(463) 評(píng)論(0)  編輯 收藏 引用 所屬分類: POJ

            色婷婷狠狠久久综合五月| 久久综合亚洲鲁鲁五月天| 精品久久久久久中文字幕人妻最新| 久久精品国产久精国产一老狼| 亚洲国产精品无码久久久不卡 | 久久精品国产69国产精品亚洲| 免费国产99久久久香蕉| 日韩欧美亚洲综合久久影院Ds | 人人狠狠综合88综合久久| 亚洲精品国产自在久久| 日本欧美久久久久免费播放网| 久久婷婷久久一区二区三区| 亚洲欧美另类日本久久国产真实乱对白| 久久天天婷婷五月俺也去| 国产高潮国产高潮久久久| 亚洲国产精品狼友中文久久久| 久久久久人妻一区二区三区vr| 国产精品九九久久免费视频 | 97精品伊人久久大香线蕉| 国产成人精品久久二区二区| 国产香蕉久久精品综合网| 热99re久久国超精品首页| 久久久久久久97| 欧美午夜A∨大片久久 | 午夜肉伦伦影院久久精品免费看国产一区二区三区 | 性做久久久久久久| 久久人人爽人爽人人爽av| 成人妇女免费播放久久久| 亚洲中文字幕无码久久精品1 | 国产午夜免费高清久久影院| 伊人色综合久久天天网| 久久午夜无码鲁丝片午夜精品| 久久久精品一区二区三区| 国产一级持黄大片99久久| 奇米综合四色77777久久| 久久无码高潮喷水| 久久性生大片免费观看性| 精品久久久久久国产三级| 久久国产乱子伦精品免费午夜| 91久久精品视频| 久久精品国产只有精品66|