• <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 1230 Pass-Muraille 貪心

            思路:

            考慮最左邊的需要移除墻的列。這列是必定要移除一些墻的。
            不妨移除右邊界較大的那些墻。

            實(shí)現(xiàn)的時(shí)候,可以用基數(shù)排序的方式來(lái)找到右邊界較大的墻。
            開(kāi)兩個(gè)數(shù)組如下:
            map[i][j] = { 第i列中,從該列開(kāi)始向右延伸,長(zhǎng)度為j的墻的數(shù)目}
            cnt[i] = {第i列中墻的數(shù)目}
            這樣代碼比較方便,速度也快。

            #include <stdio.h>
            #include 
            <string.h>

            int T, N, K;
            char map[128][128];
            int cnt[128];

            int main()
            {
                
            int x1, x2, y;
                
            int i, j, i2, j2, ans;

                scanf(
            "%d"&T);
                
            while (T--{
                    scanf(
            "%d%d"&N, &K);
                    memset(map, 
            0sizeof(map));
                    memset(cnt, 
            0sizeof(cnt));
                    
            while (N--{
                        scanf(
            "%d%d%d%d"&x1, &y, &x2, &y);
                        
            if (x1 > x2) {
                            x1 
            ^= x2;
                            x2 
            ^= x1;
                            x1 
            ^= x2;
                        }

                        
            for (i = x1; i <= x2; i++{
                            map[i][x2 
            - i + 1]++;
                            cnt[i]
            ++;
                        }

                    }

                    ans 
            = 0;
                    
            for (i = 0; i <= 100; i++{
                        
            if (cnt[i] <= K)
                            
            continue;
                        
            for (j = 100; cnt[i] > K && j > 0; j--{
                            
            while (cnt[i] > K && map[i][j]) {
                                i2 
            = i;
                                j2 
            = j;
                                
            while (j2) {
                                    map[i2][j2]
            --;
                                    cnt[i2]
            --;
                                    j2
            --;
                                    i2
            ++;
                                }

                                ans
            ++;
                            }

                        }

                    }

                    printf(
            "%d\n", ans);
                }


                
            return 0;
            }

            posted on 2010-05-24 23:20 糯米 閱讀(874) 評(píng)論(0)  編輯 收藏 引用 所屬分類: POJ

            久久精品国产一区二区电影| 99久久免费只有精品国产| 久久久久亚洲精品天堂久久久久久 | 久久婷婷五月综合97色直播| 久久婷婷五月综合国产尤物app| 亚洲综合日韩久久成人AV| 久久99精品久久久久婷婷| 久久黄视频| 99久久精品免费看国产一区二区三区| 亚洲AV无码1区2区久久| 国产精品欧美久久久久无广告| 午夜视频久久久久一区| 日产精品久久久一区二区| 久久国产成人精品国产成人亚洲| 亚洲精品国产美女久久久| 国产精品久久久久久久午夜片| 亚洲欧美日韩久久精品| 久久精品男人影院| 日本WV一本一道久久香蕉| 欧美亚洲另类久久综合| 久久久久亚洲国产| 成人亚洲欧美久久久久 | 久久无码AV中文出轨人妻| 久久人人爽人人人人片av| 久久精品成人| 四虎国产精品免费久久5151| 久久精品国产亚洲AV蜜臀色欲| 久久99久久无码毛片一区二区| AV无码久久久久不卡网站下载 | 国产一区二区三区久久| 久久久久久久精品成人热色戒| 久久久久亚洲AV成人网人人网站 | 亚洲国产成人精品91久久久| 久久99精品国产| 久久国产乱子伦精品免费强| 国产精品美女久久久m| 久久精品国产第一区二区三区| 久久亚洲精品无码AV红樱桃| 中文字幕无码精品亚洲资源网久久| 色老头网站久久网| 狠狠精品久久久无码中文字幕|