在线观看www成人影院-在线观看www日本免费网站-在线观看www视频-在线观看操-欧美18在线-欧美1级

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評(píng)論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會(huì)員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

C++中的背包問(wèn)題說(shuō)明和源碼示例

C語(yǔ)言編程學(xué)習(xí)基地 ? 來(lái)源:C語(yǔ)言編程學(xué)習(xí)基地 ? 作者:C語(yǔ)言編程學(xué)習(xí)基地 ? 2021-10-12 09:27 ? 次閱讀

問(wèn)題說(shuō)明

有N件物品和一個(gè)容量為V的背包。

第i件物品的重量是w[i],價(jià)值是v[i]。

求解將哪些物品裝入背包可使這些物品的重量總和不超過(guò)背包容量,

且價(jià)值總和最大。

功能說(shuō)明

本程序用動(dòng)態(tài)規(guī)劃的思想解決了背包問(wèn)題,并用了兩種算法:迭代法、遞歸法。在迭代法中實(shí)現(xiàn)了打印背包問(wèn)題的表格。

代碼簡(jiǎn)述

通過(guò)用戶輸入數(shù)據(jù),程序輸入檢測(cè),動(dòng)態(tài)分配空間,選擇算法, 用動(dòng)態(tài)規(guī)劃的思想求解背包問(wèn)題。

迭代法:

通過(guò)遍歷n行W列,迭代每行每列的值,并把最優(yōu)解放到 n行(在數(shù)組中為第n+1行)W列(在數(shù)組中為第W+1列)中。

遞歸法:

通過(guò)每次返回前i個(gè)物品和承重為j的最優(yōu)解, 遞歸計(jì)算總背包問(wèn)題的最優(yōu)解。

源碼示例

#include #include using namespace std;
int **T = NULL;    // 存儲(chǔ)背包問(wèn)題表格的數(shù)組指針
// 返回兩個(gè)值的最大值int max(int a, int b) {  return (a > b) ? a : b;}
// 迭代法,能顯示背包問(wèn)題的表格int packIterative(int n, int W, int *w, int *v) {    // 循環(huán)遍歷n行  for (int i = 1; i <= n; ++i)  {    // 循環(huán)遍歷W列    for (int j = 1; j <= W; ++j)    {      //第i個(gè)物品能裝下,則比較包括第i個(gè)物品和不包括第i個(gè)物品,取其最大值      if (w[i] <= j)        T[i][j] = max(v[i] + T[i - 1][j - w[i]], T[i - 1][j]);
      // 第i個(gè)物品不能裝下,則遞歸裝i-1個(gè)      else        T[i][j] = T[i - 1][j];    }  }  return T[n][W];}
// 遞歸法,不支持顯示背包問(wèn)題的表格int packRecursive(int n, int W, int *w, int *v) {  // 結(jié)束條件(初始條件),i或者j為0時(shí)最大總價(jià)值為0  if (n == 0 || W == 0) {    return 0;  }  // 第i個(gè)物品不能裝下,則遞歸裝i-1個(gè)  if (w[n] > W) {    return packRecursive(n - 1, W, w, v);  }  //第i個(gè)物品能裝下,則比較包括第i個(gè)物品和不包括第i個(gè)物品,取其最大值  else {    return max(v[n] + packRecursive(n - 1, W - w[n], w, v), packRecursive(n - 1, W, w, v));  }}
// 打印背包問(wèn)題的表格void printT(int n, int W){  // 打印n行  for (auto i = 0; i <= n; i++)  {    // 打印行數(shù)    cout << i << ":	";
    // 打印W列    for (int w = 0; w <= W; w++)    {      cout << T[i][w] << "	";    }
    // 換行    cout << endl;  }}
int main() {  int *w = NULL;    // 存儲(chǔ)每件物品重量的數(shù)組指針  int *v = NULL;    // 存儲(chǔ)每件物品價(jià)值的數(shù)組指針  int n;        // 物品個(gè)數(shù)n  int W;        // 背包總承重W
  cout << "---------------- 背包問(wèn)題 ----------------" << endl;  cout << "請(qǐng)輸入物品數(shù) n (n>=0) " << endl;
  // 輸入背包數(shù)  cin >> n;
  if (cin.fail() || n < 0)  {    cout << "輸入n錯(cuò)誤!" << endl;    system("pause");    return 0;  }
  cout << "請(qǐng)輸入背包承重量 W (W>=0) " << endl;
  // 輸入背包承重量  cin >> W;
  if (cin.fail() || W < 0)  {    cout << "輸入W錯(cuò)誤!" << endl;    system("pause");    return 0;  }
  // 分配空間  // 對(duì)w和v分配n+1大小  w = new int[n + 1];  v = new int[n + 1];
  // 對(duì)T分配n+1行,并初始化為0  T = new int *[n + 1]();  // 對(duì)T分配W+1列,并初始化為0  for (auto i = 0; i <= n; i++)  {    T[i] = new int[W + 1]();  }
  // 輸入背包的重量和價(jià)值  for (auto i = 1; i <= n; i++)  {    cout << "請(qǐng)輸入第 " << i << " 個(gè)物品的重量和價(jià)值(用空格隔開)" << endl;    cin >> w[i] >> v[i];    if (cin.fail() || w[i] < 0 || v[i] < 0)    {      cout << "輸入錯(cuò)誤!" << endl;      system("pause");      return 0;    }  }
  cout << "------------------------------------------------" << endl;  cout << "請(qǐng)選擇算法:" << endl;  cout << "【1】迭代法" << endl;  cout << "【2】遞歸法" << endl;  cout << "------------------------------------------------" << endl;
  int choose;
  // 輸入算法的選擇  cin >> choose;  switch (choose)  {  case 1:  {    // 迭代法,能顯示背包問(wèn)題的表格    cout << "能裝下物品的最大價(jià)值為 " << packIterative(n, W, w, v) << endl;    cout << "------------------------------------------------" << endl;    printT(n, W);    break;  }  case 2:  {    // 遞歸法,不支持顯示背包問(wèn)題的表格    cout << "能裝下物品的最大價(jià)值為 " << packRecursive(n, W, w, v) << endl;    break;  }  default:  {    cout << "輸入錯(cuò)誤!" << endl;    break;  }  }
  cout << "------------------------------------------------" << endl;
  delete w;  delete v;  for (int i = 0; i <= n; ++i) {    delete[] T[i];  }  delete[] T;
  system("pause");  return 0;}

今天的分享就到這里了,大家要好好學(xué)C++喲~

責(zé)任編輯:haq
聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場(chǎng)。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問(wèn)題,請(qǐng)聯(lián)系本站處理。 舉報(bào)投訴
  • 數(shù)據(jù)
    +關(guān)注

    關(guān)注

    8

    文章

    7237

    瀏覽量

    90929
  • C++
    C++
    +關(guān)注

    關(guān)注

    22

    文章

    2116

    瀏覽量

    74734

原文標(biāo)題:C++經(jīng)典算法問(wèn)題:背包問(wèn)題(迭代+遞歸算法)!含源碼示例

文章出處:【微信號(hào):cyuyanxuexi,微信公眾號(hào):C語(yǔ)言編程學(xué)習(xí)基地】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。

收藏 人收藏

    評(píng)論

    相關(guān)推薦
    熱點(diǎn)推薦

    創(chuàng)建了用于OpenVINO?推理的自定義C++和Python代碼,從C++代碼獲得的結(jié)果與Python代碼不同是為什么?

    創(chuàng)建了用于OpenVINO?推理的自定義 C++ 和 Python* 代碼。 在兩個(gè)推理過(guò)程中使用相同的圖像和模型。 從 C++ 代碼獲得的結(jié)果與 Python* 代碼不同。
    發(fā)表于 03-06 06:22

    Spire.XLS for C++組件說(shuō)明

    Spire.XLS for C++ 是一款專業(yè)的 C++ Excel 組件,可以用在各種 C++ 框架和應(yīng)用程序。Spire.XLS for C+
    的頭像 發(fā)表于 01-14 09:40 ?490次閱讀
    Spire.XLS for <b class='flag-5'>C++</b>組件<b class='flag-5'>說(shuō)明</b>

    EE-112:模擬C++的類實(shí)現(xiàn)

    電子發(fā)燒友網(wǎng)站提供《EE-112:模擬C++的類實(shí)現(xiàn).pdf》資料免費(fèi)下載
    發(fā)表于 01-03 15:15 ?0次下載
    EE-112:模擬<b class='flag-5'>C++</b><b class='flag-5'>中</b>的類實(shí)現(xiàn)

    基于無(wú)操作系統(tǒng)的STM32單片機(jī)開發(fā)附源碼

    到地址空間連續(xù)的不同大小的內(nèi)存空間,且用戶接口簡(jiǎn)單,使用方便。 源碼說(shuō)明 源碼包含memory.h 和 memory.c 兩個(gè)文件(嵌入式C
    的頭像 發(fā)表于 11-15 11:24 ?1206次閱讀

    C7000 C/C++優(yōu)化指南用戶手冊(cè)

    電子發(fā)燒友網(wǎng)站提供《C7000 C/C++優(yōu)化指南用戶手冊(cè).pdf》資料免費(fèi)下載
    發(fā)表于 11-09 15:00 ?0次下載
    <b class='flag-5'>C</b>7000 <b class='flag-5'>C</b>/<b class='flag-5'>C++</b>優(yōu)化指南用戶手冊(cè)

    TMS320C6000優(yōu)化C/C++編譯器v8.3.x

    電子發(fā)燒友網(wǎng)站提供《TMS320C6000優(yōu)化C/C++編譯器v8.3.x.pdf》資料免費(fèi)下載
    發(fā)表于 11-01 09:35 ?1次下載
    TMS320<b class='flag-5'>C</b>6000優(yōu)化<b class='flag-5'>C</b>/<b class='flag-5'>C++</b>編譯器v8.3.x

    C語(yǔ)言和C++結(jié)構(gòu)體的區(qū)別

    同樣是結(jié)構(gòu)體,看看在C語(yǔ)言和C++中有什么區(qū)別?
    的頭像 發(fā)表于 10-30 15:11 ?627次閱讀

    C7000優(yōu)化C/C++編譯器

    電子發(fā)燒友網(wǎng)站提供《C7000優(yōu)化C/C++編譯器.pdf》資料免費(fèi)下載
    發(fā)表于 10-30 09:45 ?0次下載
    <b class='flag-5'>C</b>7000優(yōu)化<b class='flag-5'>C</b>/<b class='flag-5'>C++</b>編譯器

    使用OpenVINO GenAI API在C++構(gòu)建AI應(yīng)用程序

    許多桌面應(yīng)用程序是使用 C++ 開發(fā)的,而將生成式AI(GenAI)功能集成到這些應(yīng)用程序可能會(huì)很具有挑戰(zhàn)性,尤其是因?yàn)槭褂孟?Hugging Face 這樣的 Python 庫(kù)的復(fù)雜性。C++
    的頭像 發(fā)表于 10-12 09:36 ?951次閱讀
    使用OpenVINO GenAI API在<b class='flag-5'>C++</b><b class='flag-5'>中</b>構(gòu)建AI應(yīng)用程序

    ostream在c++的用法

    ostream 是 C++ 標(biāo)準(zhǔn)庫(kù)中一個(gè)非常重要的類,它位于 頭文件(實(shí)際上,更常見的是通過(guò)包含 頭文件來(lái)間接包含 ,因?yàn)?包含了 和 )。 ostream 類及其派生類(如 std::cout
    的頭像 發(fā)表于 09-20 15:11 ?1592次閱讀

    OpenVINO2024 C++推理使用技巧

    很多人都使用OpenVINO新版的C++ 或者Python的SDK,都覺得非常好用,OpenVINO2022之后的版本C++ SDK做了大量的優(yōu)化與整理,已經(jīng)是非常貼近開發(fā)的使用習(xí)慣與推理方式。與OpenCV的Mat對(duì)象對(duì)接方式更是幾乎無(wú)縫對(duì)接,非常的方便好用。
    的頭像 發(fā)表于 07-26 09:20 ?1411次閱讀

    ModusToolbox 3.2在c代碼包含c++代碼的正確步驟是什么?

    使用 ModusToolbox 3.2 我有一個(gè)用純 C 語(yǔ)言編寫的 XMC4700 項(xiàng)目。 我正在嘗試添加一些 C++ 函數(shù),并將其合并到我的原始代碼。 我可以構(gòu)建獨(dú)立的 .cpp/.hpp
    發(fā)表于 07-23 08:21

    C++語(yǔ)言基礎(chǔ)知識(shí)

    電子發(fā)燒友網(wǎng)站提供《C++語(yǔ)言基礎(chǔ)知識(shí).pdf》資料免費(fèi)下載
    發(fā)表于 07-19 10:58 ?8次下載

    C++實(shí)現(xiàn)類似instanceof的方法

    函數(shù),可實(shí)際上C++沒有。但是別著急,其實(shí)C++中有兩種簡(jiǎn)單的方法可以實(shí)現(xiàn)類似Java的instanceof的功能。 在 C++
    的頭像 發(fā)表于 07-18 10:16 ?832次閱讀
    <b class='flag-5'>C++</b><b class='flag-5'>中</b>實(shí)現(xiàn)類似instanceof的方法

    數(shù)字濾波器是如何工作的

    之前我們?cè)?b class='flag-5'>說(shuō)明數(shù)字濾波器的時(shí)候,多為Python來(lái)進(jìn)行示例驗(yàn)證的。實(shí)際應(yīng)用,多為C/C++,無(wú)論是在嵌入式系統(tǒng)
    的頭像 發(fā)表于 06-13 10:09 ?802次閱讀
    數(shù)字濾波器是如何工作的
    主站蜘蛛池模板: www.夜| 久操免费在线 | 四虎国产精品成人永久免费影视 | 亚洲热热久久九九精品 | 国产亚洲3p无码一区二区 | 高h道具触手play肉男男 | 女bbbbxxxx视频| 资源新版在线天堂 | 天天做爽夜夜做爽 | 99热网址 | 天堂最新版在线地址 | 色欧美在线 | 一级毛片女人喷潮 | 久久伊人成人网 | 国产片在线观看狂喷潮bt天堂 | 一级特黄性生活大片免费观看 | 欧美猛性 | 国产一级簧片 | 狠狠摸狠狠操 | 国内真实下药迷j在线观看 国内自拍 亚洲系列 欧美系列 | 黄色网址大全免费 | 久草色在线 | 国模在线视频一区二区三区 | 2018国产大陆天天弄 | 天天影视网天天影网 | 年轻护士女三级 | 中文字幕第五页 | 1024你懂的国产日韩欧美 | 4hu44四虎在线观看 | 欧美成人久久 | 伊人啪啪网 | 国模网站 | 狠狠色狠狠色狠狠五月ady | 色视频免费观看高清完整 | 欧美天堂在线视频 | www.91插插插 | 天天操一操 | 天堂在线最新版www中文 | 欧美一卡二三卡四卡不卡 | 中国一级特黄高清免费的大片 | 天天拍拍天天爽免费视频 |