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

            /*
            ? Name:
            ? Copyright:
            ? Author:
            ? Date: 28-05-06 15:26
            ? Description: 5.座位調(diào)整
            百度辦公區(qū)里到處擺放著各種各樣的零食。百度人力資源部的調(diào)研發(fā)現(xiàn),員工如果可以在自己喜歡的美食旁邊工作,效率會(huì)大大提高。因此,百度決定進(jìn)行一次員工座位的大調(diào)整。

            調(diào)整的方法如下:
            1.首先將辦公區(qū)按照各種零食的擺放分成N個(gè)不同的區(qū)域(例如:可樂區(qū),餅干區(qū),牛奶區(qū)等等);
            2.每個(gè)員工對(duì)不同的零食區(qū)域有不同的喜好程度(喜好程度是1~100的整數(shù), 喜好程度越大表示該員工越希望被調(diào)整到相應(yīng)的零食區(qū)域);
            3.由于每個(gè)零食區(qū)域可以容納的員工數(shù)量有限,人力資源部希望找到一個(gè)最優(yōu)的調(diào)整方案使得總的喜好程度最大。


            輸入要求:
            文件第一行包含兩個(gè)整數(shù)N,M(N>=1,M<=300)。分別表示N個(gè)區(qū)域和M個(gè)員工;
            第二行是N個(gè)整數(shù)構(gòu)成的數(shù)列a,其中a[i]表示第i個(gè)區(qū)域可以容納的員工數(shù)(1<=a[i]<=M,a[1]+a[2]+...+a[N]=M);
            緊接著是一個(gè)M*N的矩陣P,P(i,j)表示第i個(gè)員工對(duì)第j個(gè)區(qū)域的喜好程度。例:
            3 3
            1 1 1
            100 50 25
            100 50 25
            100 50 25


            輸出要求:
            對(duì)于每個(gè)測(cè)試數(shù)據(jù),輸出可以達(dá)到的最大的喜好程度。例:
            175

            ?

            數(shù)據(jù)解釋:
            此數(shù)據(jù)只存在一種安排方法,三個(gè)員工分別安置在三個(gè)區(qū)域。最終的喜好程度為100+50+25=175


            評(píng)分規(guī)則:
            1.程序?qū)⑦\(yùn)行在一臺(tái)Linux機(jī)器上(內(nèi)存使用不作嚴(yán)格限制),在每一測(cè)試用例上運(yùn)行不能超過(guò)10秒,否則該用例不得分;
            2.要求程序能按照輸入樣例的格式讀取數(shù)據(jù)文件,按照輸出樣例的格式將運(yùn)行結(jié)果輸出到標(biāo)準(zhǔn)輸出上。如果不能正確讀入數(shù)據(jù)和輸出數(shù)據(jù),該題將不得分;
            3.該題目共有4個(gè)測(cè)試用例,每個(gè)測(cè)試用例為一個(gè)輸入文件。各測(cè)試用例占該題目分?jǐn)?shù)的比例分別為25%,25%,25%,25%;
            4.該題目20分。

            */
            /*
            算法介紹:
            1。讀入數(shù)據(jù)N,M,a[]和p[][]。
            2。以員工為主序,采用回溯的方法依次處理每一個(gè)員工在每個(gè)位置的喜好程度,返回總的最大的喜好程度。
            */

            #include <iostream>
            #include<fstream>
            #include <time.h>

            using namespace std;

            const int MAX = 301;
            void Readata(const char *filename, int a[], int p[][MAX], int & N, int & M);
            int GetPlace(int N, int maxMen, int man, const int p[][MAX], int a[]);

            int main()
            {
            ?time_t startTime;
            ?time_t endTime;
            ?time(&startTime);

            ????? int N, M;
            ????? int a[MAX] = {0};
            ????? int p[MAX][MAX] = {0};

            ?Readata("in5.txt", a, p, N, M);//讀入數(shù)據(jù)

            //?cout << M << ' ' << N << endl;
            //?for (int i=1; i<=N; i++)
            //??????????? cout << a[i] << ' ';
            //????? cout << endl;
            //????? for (int i=1; i<=M; i++)
            //????? {
            //??????????? for (int j=1; j<=N; j++)
            //????????????????? cout << p[i][j] << ' ';
            //??????????? cout << endl;
            //????? }

            ????? int sum = GetPlace(N, M, 1, p, a);//返回總的最大的喜好程度。
            ????? cout << sum << endl;

            ?time(&endTime);
            ?cout << difftime(endTime, startTime) << endl;

            ?getchar();
            ?return 0;
            }

            void Readata(const char *filename, int a[], int p[][MAX], int & N, int & M)
            {
            ????? fstream in(filename);
            ????? if (!in)
            ??????????? return ;?? //結(jié)束程序執(zhí)行

            ????? while (!in.eof())
            ????? {
            ??????????? in >> N;
            ??????????? in >> M;
            ??????????? for (int i=1; i<=N; i++)
            ????????????????? in >> a[i];
            ??????????? for (int i=1; i<=M; i++)
            ????????????????? for (int j=1; j<=N; j++)
            ??????????????????????? in >> p[i][j];
            ????? }

            ??? in.close(); //關(guān)閉文件
            }

            int GetPlace(int N, int maxMen, int man, const int p[][MAX], int a[])
            {
            ????? int max = 0;
            ????? int sum = 0;

            ????? if (man == maxMen)//處理最后一個(gè)員工
            ????? {
            ??????????? for (int i=1; i<=N; i++)
            ??????????? {
            ????????????????? if (a[i] > 0)//如果該位置還可以容納此員工,用sum記錄其在該處的喜好度
            ??????????????????????? sum = p[man][i];
            ????????????????? if (sum > max)
            ??????????????????????? max = sum;//用max記錄該員工可以獲得的最大喜好度
            ??????????? }
            ????? }
            ????? else //如果處理的不是最后一個(gè)員工,應(yīng)采用回溯方法以取得最優(yōu)解
            ????? {
            ??????????? for (int i=1; i<=N; i++)
            ??????????? {
            ????????????????? if (a[i] > 0)//如果該位置還可以容納此員工,用sum記錄其在該處的喜好度
            ????????????????? {
            ??????????????????????? a[i]--;//該位置可容納員工數(shù)減1
            ??????????????????????? sum = p[man][i] + GetPlace(N, maxMen, man+1, p, a);
            ??????????????????????? a[i]++;
            ????????????????? }
            ????????????????? if (sum > max)
            ??????????????????????? max = sum;
            ??????????? }
            ????? }
            ????? return max; //返回第man到M個(gè)員工總的最大喜好度
            }

            ?

            Posted on 2006-05-30 13:58 夢(mèng)想飛揚(yáng) 閱讀(1252) 評(píng)論(4)  編輯 收藏 引用

            Feedback

            # re: 我解百度之星題目之" 座位調(diào)整 "  回復(fù)  更多評(píng)論   

            2006-06-13 19:58 by Jacky
            拜讀了你的算法,能實(shí)現(xiàn)題目的要求。你的算法就是把每種可能的情況都遍歷一遍,從中得到最大喜好度。但覺得回溯法在這里使用的不太恰當(dāng),算法里面并沒有回溯的必要,你是把每種情況的最大喜好度算出來(lái)后通過(guò)比較才確定最大喜好度的。個(gè)人認(rèn)為本題采用動(dòng)態(tài)規(guī)劃法更好。采用回溯法也可以,但最好寫一個(gè)判斷當(dāng)前情況下能得到的最大喜好度的函數(shù),然后和當(dāng)前的最大喜好度進(jìn)行比較,如果小于當(dāng)前最大喜好度,就沒有必要再遞歸下去了。

            以上看法屬個(gè)人意見,有錯(cuò)誤或疏漏的地方請(qǐng)多指教!謝謝!

            # re: 我解百度之星題目之" 座位調(diào)整 "  回復(fù)  更多評(píng)論   

            2009-05-13 00:58 by kekedou
            這樣通過(guò)全排列的方法在時(shí)間復(fù)雜度上太大了吧。。。。有沒有更好的方法?

            # re: 我解百度之星題目之" 座位調(diào)整 "  回復(fù)  更多評(píng)論   

            2009-06-15 23:51 by kuramawzw
            網(wǎng)絡(luò)流或二分圖最佳匹配

            # re: 我解百度之星題目之" 座位調(diào)整 "  回復(fù)  更多評(píng)論   

            2012-11-27 00:06 by 無(wú)知者
            難道我理解錯(cuò)了

            這好像是錯(cuò)的

            這樣實(shí)際判斷 最后一個(gè)人 選擇哪個(gè)區(qū)域興趣多
            就去哪個(gè)區(qū)域了
            在這里 就已經(jīng)是錯(cuò)的了

            遞歸+返回值 視乎不能達(dá)到對(duì) 所有 配對(duì)方法的 遍歷
            需要一個(gè)內(nèi)存區(qū)來(lái)存放結(jié)果

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


            97精品国产97久久久久久免费| 久久国产精品成人片免费| 久久亚洲日韩精品一区二区三区| 99久久99久久精品国产片果冻| 亚洲精品乱码久久久久久中文字幕| 国产免费福利体检区久久| 久久精品成人国产午夜| 国产精品免费看久久久| 麻豆成人久久精品二区三区免费| 久久伊人五月丁香狠狠色| 亚洲欧美另类日本久久国产真实乱对白| 国产成人久久精品麻豆一区| 精品一区二区久久久久久久网站| 99国产精品久久| 麻豆精品久久精品色综合| 亚洲精品高清国产一久久| 国产精品久久久99| 久久久久国色AV免费观看| 久久99这里只有精品国产| 中文字幕日本人妻久久久免费| 久久精品国产99国产精品导航| 亚洲国产精品无码久久一线| 麻豆成人久久精品二区三区免费 | 久久本道综合久久伊人| 久久久精品国产Sm最大网站| 欧美精品丝袜久久久中文字幕 | 伊人久久大香线蕉无码麻豆| 尹人香蕉久久99天天拍| 亚洲欧美精品一区久久中文字幕 | 青草国产精品久久久久久| 精品国产乱码久久久久久郑州公司| 97久久天天综合色天天综合色hd| 青青青青久久精品国产h| 中文字幕精品久久| 亚洲国产精品18久久久久久| 97超级碰碰碰久久久久| 久久高清一级毛片| 精品综合久久久久久98| 色综合久久久久网| 超级97碰碰碰碰久久久久最新| 777米奇久久最新地址|