蛮力法之背包问题

问题:

             有 n 个重量分别是 w1,w2....,wn 的物品(物品编号为 1-n)它们的价值分别为 v1,v2,...,vn

给定一个容量为 W 的背包。设计从这些物品中选取一部分放入该背包的方案。

每个物品要么选中要么不选中【其实每个物品只有 1 件】,要求选中的物品不仅能够放在背包中,而且具有最大的价值。

并对如下所展示的 5 个物品求出 W=10 时的最佳解。

                                                           物品编号             重量            价值

                   

思路:

        

  1. 预先定义了物品的重量数组w和价值数组v,其中w[i]表示第i个物品的重量,v[i]表示第i个物品的价值。

  2. 定义了一个长度为5的数组x,用于记录物品的选取状态。x[i]的取值为1表示选取第i个物品,取值为0表示不选取第i个物品。

  3. 定义了变量maxv,用于记录最大的总价值。

  4. 定义了数组ans,用于记录最优解的选取状态。

  5. 定义了深度优先搜索函数dfs,其中参数i表示当前正在考虑的物品的索引,ww表示当前已选取的物品的总重量,vv表示当前已选取的物品的总价值。

  6. 在dfs函数中,当遍历完所有物品时(i == 5),检查当前选取状态的总重量是否不超过10,并且当前总价值是否大于最大价值。如果满足条件,更新最大价值maxv,并将当前选取状态记录到数组ans中。

  7. 在dfs函数中,首先假设选取当前物品(x[i] = 1),然后递归调用dfs函数选择下一个物品(i + 1),并更新总重量ww和总价值vv。

  8. 然后,在dfs函数中,不选取当前物品(x[i] = 0),然后递归调用dfs函数选择下一个物品(i + 1),并保持总重量ww和总价值vv不变。

  9. 在主函数中,调用dfs函数从第一个物品开始进行深度优先搜索。

  10. 最后,输出最优解的选取状态ans和最大价值maxv。

代码:

#include<iostream>
using namespace std;
int w[5] = { 2,2,6,5,4 }, v[5] = { 6,3,5,4,6 }; // 物品的重量和价值
int x[5]; // 记录物品的选取状态
int maxv = 0; // 最大价值
int ans[5]; // 最优解

// 深度优先搜索函数
void dfs(int i, int ww, int vv)
{
    if (i == 5) { // 当遍历完所有物品时
        if (ww <= 10 && vv > maxv) { // 如果总重量不超过10,并且当前价值大于最大价值
            maxv = vv; // 更新最大价值
            for(int i=0;i<5;i++) // 将当前选取状态记录到最优解中
                ans[i]=x[i];
        }
        return; // 返回上一层递归
    }

    x[i] = 1; // 选取当前物品
    dfs(i + 1, ww + w[i], vv + v[i]); // 递归选择下一个物品
    x[i] = 0; // 不选取当前物品
    dfs(i + 1, ww, vv); // 递归选择下一个物品
}

int main()
{
    dfs(0, 0, 0); // 从第一个物品开始进行深度优先搜索
    for(auto x:ans)
        cout<<x; // 输出最优解的选取状态
    cout<<endl;
    cout << maxv; // 输出最大价值
    return 0;
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mfbz.cn/a/262661.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

CSS:盒子模型

CSS&#xff1a;盒子模型 盒子模型盒子模型的组成盒子内容边框 border内边距 padding盒子实际大小计算CSS3的盒子类型content-boxborder-box 外边距 margin外边距合并相邻块元素垂直外边距合并嵌套块元素垂直外边距塌陷 行内元素的内外边距 盒子相关属性圆角边框盒子阴影 盒子模…

python之导入.py文件

目录 1、文件结构 2、导入.py文件 2.1同一层内文件夹内的导入 2.2不同层内文件夹内的导入 1、文件结构 Paint_master是一个工程的根目录&#xff0c;忽略一些文件及文件夹后&#xff0c;其文件结构如下&#xff1a; src util ImageUtil.py view BaseAdjustDialog.py MainW…

字符串函数的模拟实现(部分字符串函数)

strlen函数模拟 size_t my_strlen(const char* arr) {int count 0;while(*arr){arr;count;}return count;} int main() { printf( " %zd", my_strlen("adsshadsa"));}//模拟实现strlen函数 strcpy函数模拟 char* my_strcpy(char* arr1, const char* ar…

Python算法例21 交错正负数

1. 问题描述 给出一个含有正整数和负整数的数组&#xff0c;将其重新排列成一个正负数交错的数组。 2. 问题示例 给出数组[-1&#xff0c;-2&#xff0c;-3&#xff0c;4&#xff0c;5&#xff0c;6]&#xff0c;重新排序之后&#xff0c;变成[-1&#xff0c;5&#xff0c;-…

Web前端-JavaScript(对象)

文章目录 1.对象1.1 概念1.2 创建对象三种方式**对象字面量创建对象**&#xff1a;new Object创建对象构造函数创建对象 1.3 遍历对象 2.作用域1.1 概述1.2 全局作用域1.3 局部作用域1.4 JS没有块级作用域1.5 变量的作用域1.6 作用域链1.7 预解析 1.对象 1.1 概念 什么是对象 …

Ubuntu 磁盘管理DF命令用法

Linux磁盘空间管理是系统运维中的核心环节&#xff0c;它直接影响到系统的稳定运行、数据的安全性和业务的连续性。 通过实施有效的磁盘空间管理策略&#xff0c;系统管理员可以确保系统的高效运作&#xff0c;满足不断变化的业务需求&#xff0c;并为用户提供可靠的服务。 因此…

【YOLOv8新玩法】姿态评估解锁找圆心位置

前言 Hello大家好&#xff0c;今天给大家分享一下如何基于深度学习模型训练实现圆检测与圆心位置预测&#xff0c;主要是通过对YOLOv8姿态评估模型在自定义的数据集上训练&#xff0c;生成一个自定义的圆检测与圆心定位预测模型 制作数据集 本人从网络上随便找到了个工业工件…

自动标注软件AnyLabeling安装

AnyLabeling自动标注软件介绍 该工具作为一个具有Segment Anything和YOLO模型的智能标签工具&#xff0c;可以快速、准确地对图像进行标注。 AnyLabeling LabelImg Labelme Improved UI Auto-labeling 在Python终端运行 pip install anylabeling启动AnyLabeling anylabe…

危险品内陆运输相关知识_箱讯科技

危险品拖车 危险品拖车运输是一项涉及到高度危险物质的专业工作&#xff0c;需要确保合法合规的运输&#xff0c;并提供必要的信息以保障公共安全。进行这类运输时&#xff0c;需要携带一系列文件和具备特定的资质。 什么样的车适合做危险品拖车? 1、车辆类型&#xff1a;通…

长三角安防行业盛会“2024杭州安博会”4月份在杭州博览中心召开

作为中国安防行业的盛会&#xff0c;2024杭州安博会将于4月份在杭州国际博览中心隆重召开。本届安博会将汇聚全球最先进的安防技术和产品&#xff0c;为来自世界各地的安防从业者、爱好者以及投资者提供一个交流、展示和合作的平台。 据了解&#xff0c;2024杭州安博会将会展示…

Windows11系统下如何通过.cab文件更新PL2303串口驱动?

Windows11系统下如何通过.cab文件更新PL2303串口驱动? 首先,在微软官方网站上下载所需版本的.cab文件,具体链接如下: https://www.catalog.update.microsoft.com/Search.aspx?q=Prolific%20USB-to-Serial%20Comm%20Port 如下图所示,进入该网站后,找到自己所需的驱动版…

IPD产品开发的三类变更的含义和在流程中的位置

在基于IPD的产品开发过程中&#xff0c;变更仍然不可避免&#xff0c;甚至变更比基于传统流程的产品开发更多&#xff0c;因为IPD的产品开发是盯着市场变化、快速响应市场需求的&#xff0c;而这个世界唯一的不变就是变。那么&#xff0c;我们如何对产品开发过程中的变更进行分…

智能网络与网络安全:全球发展与未来趋势

导言 随着数字化时代的到来&#xff0c;智能网络和网络安全成为科技领域的研究热点。本文将深入研究智能网络与网络安全的发展过程、遇到的问题、解决过程&#xff0c;以及未来的可用范围。同时&#xff0c;关注各国在这一领域的应用情况和未来研究的趋势&#xff0c;以便在全球…

期货交易策略模拟测试-基于CLBISO01策略-2023.12.22

采取与昨天同样的策略进行盘中模拟测试&#xff0c;今天行情还可以&#xff0c;挺“顺溜”。

Xcode15 iOS 17 Simulator 离线安装,模拟器安装

Xcode 15 安装包的大小相比之前更小&#xff0c;因为除了 macOS 的 Components&#xff0c;其他都需要动态下载安装&#xff0c;否则提示 iOS 17 Simulator Not Installed。 如果不安装对应的运行模拟库 无法真机和模拟器运行&#xff0c;更无法新建项目。但是由于模拟器安装包…

拖拽列表简单实现

样式部分&#xff1a; <style>.item {width: 500px;text-align: center;margin-bottom: 5px;height: 40px;line-height: 40px;border-radius: 5px;color: #fff;margin: 5 auto;background-color: red;}.item.moving {background: transparent;color: transparent;border…

JNI学习(二)

静态注册 接着上篇博客学习 JNI函数 JNIEXPORT void JNICALL Java_com_example_jnidemo_TextDemo_setText(JNIEnv *env, jobject this, jstring string){ __android_log_print(ANDROID_LOG_ERROR, "test", "invoke set from C\n");char* str (char*)(*e…

【mongoose】 Model.create() no longer accepts a callback 报错解决

在最新版的 mongoose 操作 MongoDB 数据库的时候&#xff0c;当我们插入一条数据时候&#xff0c;会报错 &#xff1a;Model.create() no longer accepts a callback&#xff0c;看了很多文章都说是&#xff0c;版本太高&#xff0c;都妥协选择了降低回旧版本&#xff0c;但我就…

HotRC DS600遥控器+F-06A接收机

PWM原理说明 DS600遥控器说明 DS600遥控器的默认高电平是1.5ms 1通道 左右 2通道 前后 3通道 接管 上电后是1ms &#xff0c;按一下是2ms&#xff0c;1ms和2ms切换 DS600接收机说明 */ #include "ps2.h" #include "common.h"#define LEFT_RIGHT_CHAN…

centos7安装开源日志系统graylog5.1.2

安装包链接&#xff1a;链接&#xff1a;https://pan.baidu.com/s/1Zl5s7x1zMWpuKfaePy0gPg?pwd1eup 提取码&#xff1a;1eup 这里采用的shell脚本安装&#xff0c;脚本如下&#xff1a; 先使用命令产生2个参数代入到脚本中&#xff1a; 使用pwgen生成password_secret密码 …