青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

/*
? 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ū)域(例如:可樂(lè)區(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ù)解釋?zhuān)?br />此數(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) 閱讀(1273) 評(píng)論(4)  編輯 收藏 引用

Feedback

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

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

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

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

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

# 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   博問(wèn)   Chat2DB   管理


青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            亚洲欧美怡红院| 国产精品女主播| 夜夜嗨av色综合久久久综合网| 女人色偷偷aa久久天堂| 久热精品视频在线观看一区| 久久乐国产精品| 欧美成人免费在线观看| 亚洲国产精品久久91精品| 欧美福利一区二区三区| 亚洲人成在线观看网站高清| 中文国产亚洲喷潮| 久久久久9999亚洲精品| 欧美刺激性大交免费视频| 欧美吻胸吃奶大尺度电影| 国产精品一区二区在线| 一区二区三区在线观看欧美 | 久久一区二区三区av| 久久一区二区精品| 欧美日韩在线一区二区三区| 国产九九视频一区二区三区| 极品少妇一区二区| 亚洲私人影院在线观看| 久久激情网站| 亚洲激情一区| 免费一区视频| 久久影音先锋| 欧美精品在线一区二区| 国产精品极品美女粉嫩高清在线| 国产亚洲欧美日韩精品| 亚洲日本欧美天堂| 久久精品官网| 亚洲精品一区二区三| 午夜精品久久久久99热蜜桃导演| 乱人伦精品视频在线观看| 久久国产精品久久久| 久久在线播放| 在线亚洲一区观看| 久久免费一区| 国产精品自在欧美一区| 日韩一级免费| 欧美mv日韩mv国产网站app| 亚洲激情图片小说视频| 亚洲免费在线视频一区 二区| 快射av在线播放一区| 国产乱子伦一区二区三区国色天香| 亚洲高清资源| 久久婷婷国产麻豆91天堂| 亚洲午夜久久久久久久久电影院| 欧美99在线视频观看| 国内外成人在线| 性欧美超级视频| 一区二区不卡在线视频 午夜欧美不卡在 | 欧美一区三区二区在线观看| 欧美大片国产精品| 亚洲国产天堂久久国产91| 久久精品视频一| 午夜在线精品| 国产精品理论片| 亚洲免费一在线| 亚洲乱码一区二区| 欧美日韩日韩| 亚洲一区二区三区免费在线观看| 亚洲精品极品| 欧美色欧美亚洲另类二区| 在线视频精品| 中文精品视频| 亚洲每日更新| 99视频一区二区| 欧美国产在线观看| 免费久久久一本精品久久区| 黄色一区二区三区| 鲁大师成人一区二区三区| 久久aⅴ国产紧身牛仔裤| 国产一区二区三区免费观看 | 亚洲视频碰碰| 亚洲先锋成人| 国产真实乱偷精品视频免| 久久精品夜色噜噜亚洲aⅴ| 欧美午夜剧场| 国产精品高潮在线| 亚洲一区二区免费视频| 99亚洲视频| 最新亚洲激情| 狠狠色综合日日| 久久中文精品| 免费成人av| 亚洲一区三区电影在线观看| 亚洲一区二区三区四区五区黄| 国产精品日韩欧美| 美女国产精品| 欧美亚州在线观看| 久久久久久香蕉网| 欧美福利网址| 欧美怡红院视频一区二区三区| 欧美一级播放| 亚洲精选中文字幕| 亚洲欧美日韩一区二区三区在线| 在线观看欧美| 亚洲午夜精品久久久久久浪潮 | 久久久久久穴| 亚洲精品视频免费观看| 一区二区免费在线观看| 国产一区二区三区在线观看视频 | 最新国产成人在线观看| 亚洲性av在线| 日韩午夜视频在线观看| 久久黄色影院| 亚洲欧美日韩精品久久奇米色影视| 久久久999成人| 欧美一区二区视频免费观看| 欧美激情欧美激情在线五月| 久久久久久久久综合| 国产精品狠色婷| 亚洲精品一区久久久久久| 黄色精品免费| 亚洲免费一在线| 在线综合视频| 欧美精品1区| 欧美成黄导航| 国精产品99永久一区一区| 在线亚洲一区观看| 一本色道久久加勒比88综合| 另类天堂视频在线观看| 久久成人18免费观看| 欧美日韩一区视频| 日韩亚洲欧美一区| 在线性视频日韩欧美| 欧美电影在线免费观看网站| 久久免费视频在线观看| 国产精品综合视频| 亚洲一品av免费观看| 亚洲综合精品自拍| 国产精品播放| 亚洲欧美www| 久久精品国产亚洲5555| 国产日韩欧美精品综合| 欧美91福利在线观看| 国产伦精品一区二区三区在线观看 | 欧美激情亚洲综合一区| 欧美成人亚洲成人| 91久久久精品| 欧美韩日高清| 日韩一级欧洲| 新狼窝色av性久久久久久| 国产精品久久久久一区二区| 亚洲视频在线观看三级| 先锋影音一区二区三区| 国产精品中文在线| 久久激情网站| 亚洲高清影视| 在线视频一区二区| 国产精品豆花视频| 亚洲欧美另类国产| 免费成人在线观看视频| 亚洲日本aⅴ片在线观看香蕉| 欧美日韩精品免费观看视频| 中国亚洲黄色| 巨乳诱惑日韩免费av| 亚洲精品国产精品国自产观看浪潮 | 久久综合国产精品| 亚洲电影av| 欧美激情性爽国产精品17p| 夜久久久久久| 久久婷婷色综合| 日韩一级精品| 国产亚洲精品自拍| 欧美激情中文字幕乱码免费| 亚洲在线观看视频网站| 免费观看亚洲视频大全| 亚洲视频日本| 在线观看日韩欧美| 欧美日韩在线高清| 久久超碰97中文字幕| 亚洲精品国产精品国产自| 亚洲欧美国产三级| 亚洲国产天堂久久国产91| 欧美吻胸吃奶大尺度电影| 久久成人免费电影| 亚洲乱码国产乱码精品精可以看| 久久久久国产免费免费| 99视频精品免费观看| 国产日韩欧美精品一区| 欧美精品久久久久久久免费观看| 亚洲欧美不卡| 亚洲精品少妇| 男女视频一区二区| 欧美中在线观看| 亚洲一区二区三区视频| 亚洲国产一区二区三区青草影视| 国产精品综合av一区二区国产馆| 欧美精品尤物在线| 久久综合狠狠| 久久狠狠久久综合桃花| 亚洲深夜福利在线| 日韩一区二区电影网| 亚洲国产精品美女| 欧美aaaaaaaa牛牛影院| 久久久五月天| 久久久欧美一区二区| 午夜精品av|