0-1背包问题蛮力法求解(c++版本)

// 0.1背包求解.cpp : 定义控制台应用程序的入口点。
//
#include "stdafx.h"
#include <iostream>  
#define N 5  
#define ST 10  
using namespace std;
int main() {
 //给定n个重量,价值为不同的个物品和容量为c的背包,求这些物品中一个最有的价值的子集  
 int a[N] = { 2, 1, 3, 4, 7 };
 int b[N] = { 2, 5, 4, 1, 2 };
 int sum1 = 0;//sum1表示最终的价值  
 for (int i = 0; i<N; i++)//这是对每次的  
 {
  int STS = 0;//金子的总个数  
  int QS = 0;//价值的总个数  
  for (int j = 0; j<N; j++)
  {
   if (STS + a[i]<ST)//如果金子每放完,则继续放  
   {
    cout << "金子个数:" << a[j] << "    ";
    cout << "对应的价值为:" << a[j] * b[j] << endl;
    STS += a[j];
    QS += a[j] * b[j];
   }//否则则不进行  
  }//直到这个循环结束后就出来求出总的价值  
  cout << "第" << i + 1 << "次的总价值为:" << QS << endl;
  cout << endl;
  if (QS>sum1)
  {
   sum1 = QS;
  }
 }
 cout << "蛮力法背包最大的价值为:" << sum1 << endl;
 return 0;
}
 

 

 


结语 
> 如果你还需要了解更多技术文章信息,请继续关注白衣秀才的博客

个人网站:http://penglei.top/
Github:https://github.com/whitescholars
微博:http://weibo.com/u/3034107691?refer_flag=1001030102_&is_all=1

posted @   白衣秀才  阅读(2568)  评论(0编辑  收藏  举报
编辑推荐:
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
阅读排行:
· 周边上新:园子的第一款马克杯温暖上架
· Open-Sora 2.0 重磅开源!
· 分享 3 个 .NET 开源的文件压缩处理库,助力快速实现文件压缩解压功能!
· Ollama——大语言模型本地部署的极速利器
· DeepSeek如何颠覆传统软件测试?测试工程师会被淘汰吗?
点击右上角即可分享
微信分享提示