• <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>
            隨筆 - 68  文章 - 57  trackbacks - 0
            <2010年3月>
            28123456
            78910111213
            14151617181920
            21222324252627
            28293031123
            45678910

            常用鏈接

            留言簿(8)

            隨筆分類(74)

            隨筆檔案(68)

            搜索

            •  

            最新評論

            閱讀排行榜

            評論排行榜

              一個經典的問題:給定n個數,求其中的任意一個子集滿足集合中的每個元素值加和正好是n的倍數。剛開始怎么也沒有思路,因為n很大,直接搜索顯然是不行的。后來在組合數學書上找到了這個例題(暈,之前白看了,居然把這個經典的題目都給忘了),是抽屜原理的典型應用。
              假定n個數為a1,a2,...,an,前n項和分別是S1、S2、...、Sn,那么如果有一個Si模n是0,就是答案,否則,n個數模n的余數只能在1到n - 1之間,把余數作為抽屜,顯然n個數放到n - 1個抽屜里面,肯定有兩個數余數相等,這樣取它們的差就得到了結果,算法復雜度是O(n)的。
              抽屜原理的應用都十分巧妙。還有一個例子,一個屋子里面有n個人,他們的最大年齡不超過k歲,問是否肯定存在2組人(兩組沒有重復的人),使得這兩組人的年齡和相等。n個人的組合一共有2 ^ n種方法,注意到最大情況n的人的年齡和是n * k,這樣如果2 ^ n > n * k,根據抽屜原理,一定存在兩種組合他們的年齡和相等,而且沒有重復的人(如果重復,把那個人刪去就行了)。所以O(1)的時間就判斷出了結果。
              不過在最開始做題目(PKU 2356)的時候,雖然代碼很短,但是錯了好多次。首先是數組開小了,然后發現輸出的時候題目要求的是輸出數但是我給輸出下標了。最后的問題出在一個很關鍵的地方,在取模為零的時候,我本應該直接就記錄產生了解,但是我以為取模為零的時候下次肯定會產生重復的標記,就沒有特殊處理。其實如果第一個數取模就是0的話,就有可能后面不產生重復的標記,這樣我的程序就錯了,還有就是最后一個是取模為零的時候也會出問題。想了很久才想到這個問題,改正之后終于過了。以后寫程序要仔細,不能想當然啊。
            附PKU 2356代碼:
            #include <cstdio>
            const int N = 10010;

            int main()
            {
                
            int a[N], n, mod[N] = {0}, tmp = 0, len = 0, pos;

                scanf(
            "%d"&n);
                
            for (int i = 1; i <= n; i++)
                {
                    scanf(
            "%d"&a[i]);
                    
            if (len)    continue;
                    tmp 
            = (tmp + a[i]) % n;
                    
            if (tmp == 0)
                    {
                        len 
            = i;
                        pos 
            = 1;
                    }
                    
            if (mod[tmp])
                    {
                        len 
            = i - mod[tmp];
                        pos 
            = mod[tmp] + 1;
                    }
                    
            else
                        mod[tmp] 
            = i;
                }
                printf(
            "%d\n", len);
                
            for (int i = 0; i < len; i++)
                    printf(
            "%d\n", a[pos+i]);

                
            return 0;
            }
            posted on 2009-06-12 09:09 sdfond 閱讀(544) 評論(2)  編輯 收藏 引用 所屬分類: Algorithm - Combinatorics

            FeedBack:
            # re: 抽屜原理 - PKU 3370 & PKU 2356 2010-08-20 14:39 Adrian
            抽屜定理解的不是整除嗎,兩組人的年齡和相等怎么用抽屜定理解呢?不太清楚哎!請教,(*^__^*) 嘻嘻……  回復  更多評論
              
            # re: 抽屜原理 - PKU 3370 & PKU 2356 2010-08-21 09:02 sdfond
            @Adrian
            抽屜原理的含義你到網上查查~
            n個人如果都取最大值的話,n個人的年齡之和是n * k,因此年齡取值范圍是1到n * k。而從n個人選出任意多個人的選法有2 ^ n種,選出來的這些人年齡范圍肯定也在1到n * k之間。把年齡取值范圍當做抽屜,如果2 ^ n > n * k那么一定存在2組人年齡和相等。  回復  更多評論
              
            久久人搡人人玩人妻精品首页 | 亚洲精品无码久久久久| 欧美粉嫩小泬久久久久久久| 久久亚洲国产精品五月天婷| 亚洲伊人久久大香线蕉综合图片| 97久久精品无码一区二区| 久久久久夜夜夜精品国产| 久久亚洲精品无码播放| 日韩精品久久久久久久电影蜜臀 | 久久婷婷色综合一区二区| 久久精品亚洲一区二区三区浴池 | 久久综合久久自在自线精品自| 成人久久综合网| 97精品国产97久久久久久免费| 久久综合丁香激情久久| 亚洲国产精品18久久久久久| 久久国产V一级毛多内射| 亚洲乱码精品久久久久..| 99久久国产综合精品五月天喷水| 免费无码国产欧美久久18| 久久香蕉一级毛片| 色偷偷88888欧美精品久久久 | 国产91久久综合| 久久精品毛片免费观看| 亚洲熟妇无码另类久久久| 久久99久久无码毛片一区二区| 91视频国产91久久久| 一本一道久久综合狠狠老| 久久婷婷五月综合97色直播| 日日狠狠久久偷偷色综合96蜜桃| 天天久久狠狠色综合| 国产精品一区二区久久| 91久久精一区二区三区大全| 国产精品无码久久综合| 久久99国产乱子伦精品免费| 亚洲综合熟女久久久30p| 思思久久好好热精品国产| 伊人久久大香线蕉综合网站| 久久综合伊人77777| 亚洲精品久久久www| 国产精品久久久久久久app|