C++超詳細講解貪心策略的設(shè)計及解決會場安排問題
問題描述
設(shè)有n個會議的集合C={1,2,…,n},其中每個會議都要求使用同一個資源(如會議室),而在同一時間內(nèi)只能有一個會議使用該資源。每個會議i都有要求使用該資源的起始時間bi和結(jié)束時間ei,且bi < ei 。如果選擇了會議i使用會議室,則它在半開區(qū)間[bi, ei)內(nèi)占用該資源。如果[bi, ei)與[bj , ej)不相交,則稱會議i與會議j是相容的。會場安排問題要求在所給的會議集合中選出最大的相容活動子集,也即盡可能地選擇更多的會議來使用資源。
貪心策略
1、選擇最早開始時間且不與已安排會議重疊的會議
2、選擇使用時間最短且不與已安排會議重疊的會議
3、選擇具有最早結(jié)束時間且不與已安排會議重疊的會議
這里我選取第三種方法
算法設(shè)計
設(shè)有11個會議等待安排,用貪心法找出滿足目標要求的會議集合。這些會議按結(jié)束時間的非減序排列如表所示
11個會議按結(jié)束時間的非減序排列表:
代碼實現(xiàn)
#include <iostream> #include "會場安排.h" #define n 11 struct meeting{ int B;//開始時間 int E;//結(jié)束時間 }; using namespace std; int main() { meeting M[n] = { {8,11}, {8,12}, {2,13}, {12,14}, {1,4}, {3,5}, {0,6}, {5,7}, {3,8}, {5,9}, {6,10} }; for(int i=0;i<n;i++) for(int j=0;j<n-i-1;j++) if (M[j].E > M[j + 1].E) { meeting T; T = M[j]; M[j]= M[j+ 1]; M[j+1]= T; } int allowedTime = 0; for (int i = 0,j=0; i < n; i++) { if (M[i].B > allowedTime) { j++; cout << "安排的第"<<j<<"個會議號是 " << i+1 <<" 此會議開始時間為:" << M[i].B <<" 此會議結(jié)束時間是:" << M[i].E << endl; allowedTime = M[i].E; } } }
選擇結(jié)構(gòu)體
定義meeting結(jié)構(gòu)體,只設(shè)置會議開始時間B和結(jié)束時間E即可。
隨機輸入會議
n 為11
meeting M[n] = { {8,11}, {8,12}, {2,13}, {12,14}, {1,4},
{3,5}, {0,6}, {5,7}, {3,8}, {5,9}, {6,10} };
按結(jié)束時間排序
冒泡排序?qū)崿F(xiàn)即可:
for(int i=0;i<n;i++)
for(int j=0;j<n-i-1;j++) if (M[j].E > M[j + 1].E)
{
meeting T; T = M[j]; M[j]= M[j+ 1]; M[j+1]= T;
}
這里的中間變量必須設(shè)置為 meeting 類型,以便于將會議的所有屬性都交換
最終會議確定
int allowedTime = 0;
for (int i = 0,j=0; i < n; i++) {
if (M[i].B > allowedTime) {
j++;
cout << "安排的第"<<j<<"個會議號是 " << i+1 <<" 此會議開始時間為:" << M[i].B
<<" 此會議結(jié)束時間是:" << M[i].E << endl;
allowedTime = M[i].E;
}
}
先將會議開始時間設(shè)置為0,只要把按結(jié)束時間升序排列的第一個大于0的開始時間加到第一個內(nèi)容哦即可,隨后將第一個會議的結(jié)束時間設(shè)置為allowedTime,產(chǎn)生下一個不與第一個會議時間沖突的會議;然后自己加點輸出語句,美觀的運行出來結(jié)果就好了。
結(jié)束語
這算是貪心法第一個案例,也是比較好理解的一個案例,希望大家分析后都能有自己的收獲,下篇博客再見,覺得好就鼓勵鼓勵博主吧
到此這篇關(guān)于C++超詳細講解貪心策略的設(shè)計及解決會場安排問題的文章就介紹到這了,更多相關(guān)C++貪心策略內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
關(guān)于C++使用std::chrono獲取當(dāng)前秒級/毫秒級/微秒級/納秒級時間戳問題
這篇文章主要介紹了C++使用std::chrono獲取當(dāng)前秒級/毫秒級/微秒級/納秒級時間戳,本文通過實例代碼給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2023-07-07C語言中二維數(shù)組作為函數(shù)參數(shù)來傳遞的三種方法
這篇文章主要給大家介紹了關(guān)于C語言中二維數(shù)組作為函數(shù)參數(shù)來傳遞的三種方法,文中通過示例代碼介紹的非常詳細,對大家學(xué)習(xí)或者使用C語言有一定的參考學(xué)習(xí)價值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧2019-09-09詳解vs2022創(chuàng)建及調(diào)用.lib的方法
這篇文章主要介紹了vs2022創(chuàng)建及調(diào)用.lib的方法,調(diào)用Lib的原則就是可以讓編譯器找到頭文件和庫文件的目錄,并正確引入,本文給大家詳細講解需要的朋友可以參考下2022-11-11VC下通過系統(tǒng)快照實現(xiàn)進程管理的方法
這篇文章主要介紹了VC下通過系統(tǒng)快照實現(xiàn)進程管理的方法,較為詳細的講述了VC下通過系統(tǒng)快照實現(xiàn)進程管理的原理與具體實現(xiàn)方法,非常具有實用價值,需要的朋友可以參考下2014-10-10