• <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>
            隨筆 - 51, 文章 - 1, 評(píng)論 - 41, 引用 - 0
            數(shù)據(jù)加載中……

            智力題:5個(gè)強(qiáng)盜分100個(gè)金幣

                   本文用遞歸方法解決一個(gè)智力題。題目如下:5個(gè)強(qiáng)盜分100個(gè)金幣,如果第一個(gè)人提出的分配方案得到半數(shù)以上(含半數(shù))的人同意則執(zhí)行,否則處死第一個(gè)人,再由第二個(gè)人提出方案,直到分配完成。第一個(gè)人提出怎樣的方案才能既獲得最大利益又沒(méi)有殺身之禍?這里假設(shè)每個(gè)人都是理性的且追求最大的利益。

                第1個(gè)提出的分配方案要滿足兩個(gè)條件,一是得到半數(shù)以上的人支持。二是使自己獲得最大的利益。為了取得別人的支持需要給他們部分利益,顯然這部分利益要超過(guò)他們?cè)诘?/span>2個(gè)人提出的可接受分配方案中所獲得的利益。如果不這樣,他們會(huì)反對(duì),從而接受第2個(gè)人提出的方案。
                問(wèn)題變成了求第2個(gè)人提出的可接受方案。他的方案也要滿足上面的兩點(diǎn)。以此類推,問(wèn)題變成最后一個(gè)人提出可接受方案,顯然可以提可接受的方案,因?yàn)闆](méi)有人反對(duì),把金幣全部分給自己。

            下面是他們的方案:
            第5個(gè)人的方案0000100。(不需要?jiǎng)e人的支持)
            第4個(gè)人的方案0001000(不需要?jiǎng)e人的支持)
            第3個(gè)人的方案:009901。(第5個(gè)人會(huì)支持他)
            第2個(gè)人的方案:099010。(第4個(gè)人會(huì)支持他)
            第1個(gè)人的方案:980101。(第3,5個(gè)人會(huì)支持他)

                從分析中可得,這個(gè)問(wèn)題可以用遞歸求解,把求n個(gè)人的分配問(wèn)題變成求n-1個(gè)人的分配,實(shí)現(xiàn)代碼如下。

            #include <vector>

            // 得到最大利潤(rùn)分配
            // 輸入?yún)?shù):people有多少個(gè)人分配
            // 輸入?yún)?shù):gold有多少金幣
            // 輸出參數(shù):p_get分別方案
            void GetMaxProfits(
            int people, int gold, std::vector<int>& p_get)
            {
                
            // 除去自己,還需要得到多少人的支持
                
            int vote = (people+1)/2-1;
            //    int vote = people/2;

                
            if (vote > 0)    // 需要其他人的支持
                {
                    
            // 得到people-1個(gè)人數(shù)的最佳分配方案
                    GetMaxProfits(people
            -1, gold, p_get);

                    
            // 計(jì)算為了得到vote人數(shù)的支持,需要讓出多少利益
                    
            int min = gold+1;    // 需要讓出的利益,初始為一個(gè)較大的數(shù)
                    std::vector
            <int> tmpset(vote, 0);;    // 記錄給哪些人讓利

                    
            // 找出得到較少利益的vote個(gè)人
                    
            for (int i=0, c=0; i<people-1 && c<vote; i++)
                    {
                        
            int seq = 0;
                        
            for (int j=0; j<people-1; j++)
                        {
                            
            if (p_get[i] > p_get[j])
                                seq
            ++;
                        }
                        
            if (seq < vote)
                        {
                            tmpset[c
            ++= i;
                        }
                    }

                    
            // 記錄需要讓利的人在people-1情況下的利益
                    std::vector
            <int> voteprofit(vote, 0);
                    
            for (int i=0; i<tmpset.size(); i++)
                        voteprofit[i] 
            = p_get[tmpset[i]];

                    
            // 不需要讓利的人分配0個(gè)金幣
                    
            for (int i=0; i<people-1; i++)
                        p_get[i] 
            = 0;

                    
            // 給需要讓利的人分配金幣
                    
            int surplus = gold;    // 還有多少可分配的
                    
            for (int i=0; i<tmpset.size(); i++)
                    {
                        p_get[tmpset[i]] 
            = voteprofit[i];
                        surplus 
            -= voteprofit[i];
                        
            if (surplus > 0)    // 有余額多分配一個(gè)
                        {
                            p_get[tmpset[i]]
            ++;
                            surplus
            --;
                        }
                        
            else
                            break;
                    }

                    
            // 自己的利益
                    p_get[people
            -1= surplus;
                }
                
            else        // 不需要其他人的支持
                {
                    
            for (int i=0; i<people-1; i++)
                        p_get[i] 
            = 0;
                    p_get[people
            -1= gold;
                }
            }

            int main(void)
            {
                
            int gold;
                
            int people;
                printf(
            "Input gold, people:");
                scanf(
            "%d,%d"&people, &gold);

                std::vector
            <int> p_get(people, 0);
                GetMaxProfits(people, gold, p_get);
                
                
            for (int i=0; i<people; i++)
                    printf(
            "%d\t",p_get[i]);
                
                return 
            0;
            }

                    這道題的答案有些讓人吃驚,本以為第一個(gè)人最危險(xiǎn),反而能獲得較大利益。問(wèn)題出在題目的假設(shè):每個(gè)人都是理性的且追求最大的利益,從而低估了生命的價(jià)值。

            posted on 2007-11-09 21:10 lemene 閱讀(7199) 評(píng)論(10)  編輯 收藏 引用

            評(píng)論

            # re: 智力題:5個(gè)強(qiáng)盜分100個(gè)金幣  回復(fù)  更多評(píng)論   

            我覺(jué)得應(yīng)該是這樣的,第五個(gè)人可以一直反對(duì),除非把所有的金幣都給他。我假定如下,如果對(duì)下一個(gè)海盜來(lái)說(shuō),得到的金幣數(shù)量沒(méi)有變化的話,會(huì)選擇贊同,每個(gè)人都很聰明。
            我們給所有的強(qiáng)盜都編上號(hào),從一號(hào)到五號(hào)。如果最后只剩下四號(hào)和五號(hào),那么四號(hào)想活命的唯一選擇是把錢都給5號(hào)。如果剩下3個(gè)人,三號(hào)想活命就比較好辦,給4號(hào)一點(diǎn)錢就行,(0,0,99,1,0)對(duì)4號(hào)來(lái)說(shuō)不同意就得死或者一個(gè)金幣也沒(méi)有(變成兩個(gè)人)。如果有4個(gè)人,2號(hào)得選擇如下,因?yàn)閷?duì)3號(hào)來(lái)講,他的最高可以到99,所以如果不到99,他可以盡情反對(duì)。所以這次是(0,98,0,1,1)對(duì)4號(hào)來(lái)說(shuō),這是可以接受的。對(duì)5號(hào)來(lái)說(shuō),這總比上一種情況要好。
            1號(hào)需要兩個(gè)人支持是(98,0,0,1,1),因?yàn)槿绻惶?hào)的方案通不過(guò),2,3號(hào)都有機(jī)會(huì)拿到大頭所以一定會(huì)反對(duì)。
            現(xiàn)每個(gè)人在各種情況下的收益如下:(一個(gè)人,兩個(gè)人,。。。五個(gè)人):
            1號(hào):(0,0,0,0,98)
            2號(hào):(0,0,0,99,0)
            3號(hào):(0,0,99,0,0)
            4號(hào):(0,0,1,1,1)
            5號(hào):(100,100,0,1,1)
            2007-11-12 21:12 | 我思故我在

            # re: 智力題:5個(gè)強(qiáng)盜分100個(gè)金幣[未登錄](méi)  回復(fù)  更多評(píng)論   

            可能我沒(méi)有把題目說(shuō)清楚,提出方案的人也能參與投票,而且只要達(dá)到半數(shù)的票方案就可以通過(guò)。在這樣的前提下,如果只剩下4號(hào)和5號(hào),4號(hào)會(huì)全部分給自己,因?yàn)?號(hào)會(huì)投自己一票,1vs1通過(guò)。@我思故我在

            2007-11-12 21:47 | lemene

            # re: 智力題:5個(gè)強(qiáng)盜分100個(gè)金幣  回復(fù)  更多評(píng)論   

            微軟題,流行很久了,呵呵
            2008-01-20 21:00 | 伏志

            # re: 智力題:5個(gè)強(qiáng)盜分100個(gè)金幣  回復(fù)  更多評(píng)論   

            上述答案的漏洞在于:在這里你要考慮到4號(hào),4號(hào)要是認(rèn)為1號(hào)太貪得無(wú)厭的話,會(huì)不同意,支持3號(hào)也一樣至少可以得到1元。還有,若剩下了3 、4、 5,你是3號(hào)的話你會(huì)冒著生命危險(xiǎn)拿99嗎!?你要是4號(hào)會(huì)不會(huì)一塊不要而殺掉貪得無(wú)厭的3號(hào)!
            2008-12-19 19:08 | 生之痕

            # re: 智力題:5個(gè)強(qiáng)盜分100個(gè)金幣  回復(fù)  更多評(píng)論   

            你要是3號(hào)你會(huì)不會(huì)和4號(hào)每人50呢!?我想我會(huì)。那樣安全的多。

            # re: 智力題:5個(gè)強(qiáng)盜分100個(gè)金幣[未登錄](méi)  回復(fù)  更多評(píng)論   

            這個(gè)問(wèn)題的假設(shè)是每個(gè)強(qiáng)盜追求最多的利益,而且強(qiáng)盜間沒(méi)有聯(lián)合。從第一個(gè)人的方案看,如果第3和第5號(hào)強(qiáng)盜不支持他,他們可能就一塊金幣也得不到。如果這問(wèn)題考慮到生命的價(jià)值和互相聯(lián)合,問(wèn)題就復(fù)雜了。
            2009-01-19 11:17 | lemene

            # re: 智力題:5個(gè)強(qiáng)盜分100個(gè)金幣  回復(fù)  更多評(píng)論   

            樓主答案錯(cuò)誤!~
            原因是:第3個(gè)人和第一個(gè)人的分配方案中!對(duì)第5個(gè)人而言都是1枚金幣!~
            同等條件下,你不能保證5號(hào)會(huì)投一號(hào)的票!因?yàn)樗€有一次選擇的機(jī)會(huì)!!
            所以應(yīng)該是97、0、1、0、2!
            用數(shù)學(xué)模型解釋很不錯(cuò)!~
            可是小于等于2和小于2的機(jī)會(huì),在實(shí)際中是天壤之別的。5號(hào)的機(jī)會(huì)是小于等于2不是小于2,從心理學(xué)的角度上,這人如果正常肯定是肯定不會(huì)投1號(hào)的!
            所以樓主的答案沒(méi)有注意到這個(gè)小小的問(wèn)題,導(dǎo)致你的推論于實(shí)際完全不符。
            2009-04-07 12:38 | wx

            # re: 智力題:5個(gè)強(qiáng)盜分100個(gè)金幣[未登錄](méi)  回復(fù)  更多評(píng)論   

            To wx
            假設(shè)第5個(gè)人不投1號(hào)一票,那么在第2個(gè)人分配時(shí),他的投票就不起作用,最終分配結(jié)果可能是:
            1 2 3 4 5
            X 99 0 1 0
            那么5號(hào)就一個(gè)金幣也得不到。
            2009-04-08 21:33 | lemene

            # re: 智力題:5個(gè)強(qiáng)盜分100個(gè)金幣  回復(fù)  更多評(píng)論   

            理性的強(qiáng)盜總是貪婪的。

            如果各位是第三號(hào)強(qiáng)盜,你會(huì)同意1,2號(hào)強(qiáng)盜的意見(jiàn)嗎?不會(huì)的,因?yàn)?,2號(hào)強(qiáng)盜死了,第四號(hào)強(qiáng)盜為了保命一定為同意三號(hào)強(qiáng)盜的任何分配意見(jiàn)的,因此,三號(hào)強(qiáng)盜能希望,1,2號(hào)都死,自己能獲得最大的100。

            第四號(hào)強(qiáng)盜為了避免自己的這種命運(yùn)的發(fā)生肯定不會(huì)讓1,2號(hào)強(qiáng)盜去死的,誰(shuí)給他更多,他就會(huì)支持誰(shuí),他有2個(gè)選擇,但是他同樣清楚他必須聯(lián)合第5個(gè)強(qiáng)盜,不然分配方案無(wú)法通過(guò)

            而作為第五號(hào)強(qiáng)盜來(lái)說(shuō),知道讓1,2號(hào)強(qiáng)盜死了,自己肯定什么也拿不到任何東西,所以他的心態(tài)和第四號(hào)強(qiáng)盜是一樣的。

            因此第一號(hào)強(qiáng)盜要生存,唯一的辦法就是把100個(gè)金幣平分給第四和第五個(gè)強(qiáng)盜,因?yàn)樗黄椒帧5谒暮偷谖逄?hào)強(qiáng)盜就會(huì)幻想第二號(hào)強(qiáng)盜給他們更多,第二號(hào)強(qiáng)盜就可能會(huì)平分給他們,

            對(duì)于第一二號(hào)強(qiáng)盜來(lái)說(shuō),要有兩票才能保命,而這兩票就是第四五號(hào)強(qiáng)盜。

            對(duì)于此時(shí)的第一號(hào)強(qiáng)盜還沒(méi)有完,當(dāng)他知道第二號(hào)強(qiáng)盜這樣的心思的時(shí)候,他會(huì)考慮獲得第二號(hào)強(qiáng)盜和第四號(hào)或者第五號(hào)強(qiáng)盜的支持,所以我人物結(jié)果可能是:

            A,49,B,1,C,0,D,51,E,0

            或者:A,49,B,1,C,0,D,0,E51
            2011-05-18 16:20 | 流沙

            # re: 智力題:5個(gè)強(qiáng)盜分100個(gè)金幣  回復(fù)  更多評(píng)論   

            試一下不登陸可不可以評(píng)論
            2012-08-10 10:50 | xxoo

            只有注冊(cè)用戶登錄后才能發(fā)表評(píng)論。
            網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問(wèn)   Chat2DB   管理


            午夜精品久久久久久久无码| 一本色道久久88加勒比—综合| 亚洲嫩草影院久久精品| 久久久久99精品成人片试看| 久久婷婷国产剧情内射白浆| 伊人久久大香线蕉AV一区二区| 久久精品亚洲精品国产欧美| 久久精品国产国产精品四凭| 久久se这里只有精品| 久久精品成人免费观看97| 久久国产福利免费| 日产久久强奸免费的看| 色8激情欧美成人久久综合电| 日韩va亚洲va欧美va久久| 四虎亚洲国产成人久久精品| 久久人人爽人人爽人人爽| 亚洲中文字幕无码久久2020| 久久99精品久久久久子伦| aaa级精品久久久国产片| 久久99久久99小草精品免视看| 久久综合综合久久97色| 麻豆久久| 久久精品国产亚洲AV嫖农村妇女| 日本三级久久网| 久久笫一福利免费导航 | 国产精品久久新婚兰兰| 中文字幕无码久久人妻| 国产精品免费福利久久| 久久综合狠狠综合久久97色| 亚洲AV无码久久精品狠狠爱浪潮| 久久精品国产久精国产思思| 国产免费久久久久久无码| 国内精品综合久久久40p| 99久久婷婷国产一区二区| 久久精品青青草原伊人| 久久91综合国产91久久精品| 午夜精品久久久久久影视777| 精品久久久久久久无码 | 九九久久精品无码专区| 久久精品人人做人人爽电影| 久久精品无码一区二区三区免费 |