欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

C++超詳細(xì)講解貪心策略的設(shè)計(jì)及解決會(huì)場安排問題

 更新時(shí)間:2022年05月27日 10:44:16   作者:對(duì)象new不出來  
為了更好的應(yīng)對(duì)《算法設(shè)計(jì)與分析》這門課程,我把書上以及老師講過的案例都詳細(xì)的做一個(gè)重現(xiàn)及解剖,讓你熟記每一個(gè)潛在的考點(diǎn),希望能給大家?guī)椭?/div>

問題描述

設(shè)有n個(gè)會(huì)議的集合C={1,2,…,n},其中每個(gè)會(huì)議都要求使用同一個(gè)資源(如會(huì)議室),而在同一時(shí)間內(nèi)只能有一個(gè)會(huì)議使用該資源。每個(gè)會(huì)議i都有要求使用該資源的起始時(shí)間bi和結(jié)束時(shí)間ei,且bi < ei 。如果選擇了會(huì)議i使用會(huì)議室,則它在半開區(qū)間[bi, ei)內(nèi)占用該資源。如果[bi, ei)與[bj , ej)不相交,則稱會(huì)議i與會(huì)議j是相容的。會(huì)場安排問題要求在所給的會(huì)議集合中選出最大的相容活動(dòng)子集,也即盡可能地選擇更多的會(huì)議來使用資源。

貪心策略

1、選擇最早開始時(shí)間且不與已安排會(huì)議重疊的會(huì)議

2、選擇使用時(shí)間最短且不與已安排會(huì)議重疊的會(huì)議

3、選擇具有最早結(jié)束時(shí)間且不與已安排會(huì)議重疊的會(huì)議

這里我選取第三種方法

算法設(shè)計(jì)

設(shè)有11個(gè)會(huì)議等待安排,用貪心法找出滿足目標(biāo)要求的會(huì)議集合。這些會(huì)議按結(jié)束時(shí)間的非減序排列如表所示

11個(gè)會(huì)議按結(jié)束時(shí)間的非減序排列表:

代碼實(shí)現(xiàn)

#include <iostream>
#include "會(huì)場安排.h"
#define n 11
struct meeting{
	int B;//開始時(shí)間
	int E;//結(jié)束時(shí)間
};
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<<"個(gè)會(huì)議號(hào)是 " << i+1 <<" 此會(huì)議開始時(shí)間為:" << M[i].B 
				<<" 此會(huì)議結(jié)束時(shí)間是:" << M[i].E << endl;
			allowedTime = M[i].E;
		}
	}
}

選擇結(jié)構(gòu)體

定義meeting結(jié)構(gòu)體,只設(shè)置會(huì)議開始時(shí)間B和結(jié)束時(shí)間E即可。

隨機(jī)輸入會(huì)議

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é)束時(shí)間排序

冒泡排序?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 類型,以便于將會(huì)議的所有屬性都交換

最終會(huì)議確定

int allowedTime = 0;
    for (int i = 0,j=0; i < n; i++) {
        if (M[i].B > allowedTime) {
            j++;
            cout << "安排的第"<<j<<"個(gè)會(huì)議號(hào)是 " << i+1 <<" 此會(huì)議開始時(shí)間為:" << M[i].B 
                <<" 此會(huì)議結(jié)束時(shí)間是:" << M[i].E << endl;
            allowedTime = M[i].E;
        }
    }

先將會(huì)議開始時(shí)間設(shè)置為0,只要把按結(jié)束時(shí)間升序排列的第一個(gè)大于0的開始時(shí)間加到第一個(gè)內(nèi)容哦即可,隨后將第一個(gè)會(huì)議的結(jié)束時(shí)間設(shè)置為allowedTime,產(chǎn)生下一個(gè)不與第一個(gè)會(huì)議時(shí)間沖突的會(huì)議;然后自己加點(diǎn)輸出語句,美觀的運(yùn)行出來結(jié)果就好了。

結(jié)束語

這算是貪心法第一個(gè)案例,也是比較好理解的一個(gè)案例,希望大家分析后都能有自己的收獲,下篇博客再見,覺得好就鼓勵(lì)鼓勵(lì)博主吧

到此這篇關(guān)于C++超詳細(xì)講解貪心策略的設(shè)計(jì)及解決會(huì)場安排問題的文章就介紹到這了,更多相關(guān)C++貪心策略內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • C語言實(shí)現(xiàn)鏈隊(duì)列

    C語言實(shí)現(xiàn)鏈隊(duì)列

    這篇文章主要為大家詳細(xì)介紹了C語言實(shí)現(xiàn)鏈隊(duì)列,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2018-07-07
  • C++中的繼承模式深入詳解

    C++中的繼承模式深入詳解

    這篇文章主要介紹了C++中的繼承模式深入詳解。繼承是OOP設(shè)計(jì)中的重要概念。在C++語言中,派生類繼承基類有三種繼承方式:私有繼承(private)、保護(hù)繼承(protected)和公有繼承(public)。
    2021-03-03
  • 關(guān)于C++使用std::chrono獲取當(dāng)前秒級(jí)/毫秒級(jí)/微秒級(jí)/納秒級(jí)時(shí)間戳問題

    關(guān)于C++使用std::chrono獲取當(dāng)前秒級(jí)/毫秒級(jí)/微秒級(jí)/納秒級(jí)時(shí)間戳問題

    這篇文章主要介紹了C++使用std::chrono獲取當(dāng)前秒級(jí)/毫秒級(jí)/微秒級(jí)/納秒級(jí)時(shí)間戳,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2023-07-07
  • C語言中二維數(shù)組作為函數(shù)參數(shù)來傳遞的三種方法

    C語言中二維數(shù)組作為函數(shù)參數(shù)來傳遞的三種方法

    這篇文章主要給大家介紹了關(guān)于C語言中二維數(shù)組作為函數(shù)參數(shù)來傳遞的三種方法,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用C語言有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-09-09
  • 詳解vs2022創(chuàng)建及調(diào)用.lib的方法

    詳解vs2022創(chuàng)建及調(diào)用.lib的方法

    這篇文章主要介紹了vs2022創(chuàng)建及調(diào)用.lib的方法,調(diào)用Lib的原則就是可以讓編譯器找到頭文件和庫文件的目錄,并正確引入,本文給大家詳細(xì)講解需要的朋友可以參考下
    2022-11-11
  • VC下通過系統(tǒng)快照實(shí)現(xiàn)進(jìn)程管理的方法

    VC下通過系統(tǒng)快照實(shí)現(xiàn)進(jìn)程管理的方法

    這篇文章主要介紹了VC下通過系統(tǒng)快照實(shí)現(xiàn)進(jìn)程管理的方法,較為詳細(xì)的講述了VC下通過系統(tǒng)快照實(shí)現(xiàn)進(jìn)程管理的原理與具體實(shí)現(xiàn)方法,非常具有實(shí)用價(jià)值,需要的朋友可以參考下
    2014-10-10
  • Qt操作SQLite數(shù)據(jù)庫的教程詳解

    Qt操作SQLite數(shù)據(jù)庫的教程詳解

    SQLite是一款開源、輕量級(jí)、跨平臺(tái)的數(shù)據(jù)庫,無需server,無需安裝和管理配置。它的設(shè)計(jì)目標(biāo)是嵌入式的,所以很適合小型應(yīng)用,也是Qt應(yīng)用開發(fā)種常用的一種數(shù)據(jù)庫。本文為大家介紹了Qt操作SQLite數(shù)據(jù)庫的示例,希望對(duì)大家有所幫助
    2022-12-12
  • 使用C++實(shí)現(xiàn)位圖處理

    使用C++實(shí)現(xiàn)位圖處理

    本文介紹了如何使用C++語言處理位圖圖像,包括讀取、修改、保存等操作。通過具體的代碼示例,讀者可以學(xué)習(xí)到如何利用C++中的位運(yùn)算、數(shù)組和文件操作等知識(shí)點(diǎn)完成位圖處理任務(wù)。同時(shí),本文也提供了一些常用的圖像處理算法供讀者參考,幫助讀者更好地理解位圖處理過程
    2023-04-04
  • C++ 兩個(gè)vector對(duì)象拼接方式

    C++ 兩個(gè)vector對(duì)象拼接方式

    這篇文章主要介紹了C++ 兩個(gè)vector對(duì)象拼接方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-11-11
  • 一文搞懂C++ 動(dòng)態(tài)內(nèi)存

    一文搞懂C++ 動(dòng)態(tài)內(nèi)存

    這篇文章主要介紹了C++ 動(dòng)態(tài)內(nèi)存的的相關(guān)資料,文中示例代碼非常詳細(xì),幫助大家更好的理解和學(xué)習(xí),感興趣的朋友可以了解下
    2020-06-06

最新評(píng)論