• <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
            <2009年10月>
            27282930123
            45678910
            11121314151617
            18192021222324
            25262728293031
            1234567

            常用鏈接

            留言簿(8)

            隨筆分類(74)

            隨筆檔案(68)

            搜索

            •  

            最新評(píng)論

            閱讀排行榜

            評(píng)論排行榜

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

            FeedBack:
            # re: 抽屜原理 - PKU 3370 & PKU 2356 2010-08-20 14:39 Adrian
            抽屜定理解的不是整除嗎,兩組人的年齡和相等怎么用抽屜定理解呢?不太清楚哎!請(qǐng)教,(*^__^*) 嘻嘻……  回復(fù)  更多評(píng)論
              
            # re: 抽屜原理 - PKU 3370 & PKU 2356 2010-08-21 09:02 sdfond
            @Adrian
            抽屜原理的含義你到網(wǎng)上查查~
            n個(gè)人如果都取最大值的話,n個(gè)人的年齡之和是n * k,因此年齡取值范圍是1到n * k。而從n個(gè)人選出任意多個(gè)人的選法有2 ^ n種,選出來的這些人年齡范圍肯定也在1到n * k之間。把年齡取值范圍當(dāng)做抽屜,如果2 ^ n > n * k那么一定存在2組人年齡和相等。  回復(fù)  更多評(píng)論
              
            国产精品中文久久久久久久| 久久精品无码专区免费东京热| www.久久99| 9191精品国产免费久久| 久久成人精品| 综合久久精品色| 久久发布国产伦子伦精品| 久久伊人精品青青草原高清| 狠狠精品干练久久久无码中文字幕| 无夜精品久久久久久| 久久天天躁狠狠躁夜夜96流白浆| 99久久www免费人成精品| 久久久久久国产a免费观看黄色大片 | 久久免费精品视频| 亚洲精品乱码久久久久久不卡| 久久丫精品国产亚洲av不卡| 色综合合久久天天给综看| 久久精品国产99久久无毒不卡| 精品久久久久久久中文字幕 | 精品久久久久久中文字幕人妻最新| 久久免费视频观看| 亚洲AV无码成人网站久久精品大| 国产成人精品久久一区二区三区av | 2020国产成人久久精品| 99久久免费只有精品国产| 日日噜噜夜夜狠狠久久丁香五月| 亚洲精品无码专区久久同性男| 久久亚洲高清观看| 久久狠狠高潮亚洲精品| 日韩精品久久久久久久电影蜜臀 | 午夜精品久久影院蜜桃| 大美女久久久久久j久久| 国产成人久久精品激情| 一本色道久久综合狠狠躁| 亚洲国产成人精品91久久久| 国产伊人久久| 久久e热在这里只有国产中文精品99| 久久99国产亚洲高清观看首页| 99久久精品国产免看国产一区| 久久久噜噜噜久久中文福利| 性色欲网站人妻丰满中文久久不卡|