贪心算法背包问题c

在背包问题中,贪心算法通常用来解决0-1背包问题,也就是每种物品都有固定数量,你可以选择拿或者不拿,但不可以拿走部分。以下是一个用C语言实现的贪心算法的例子:

  1. #include <stdio.h>
  2. #define MAX_N 1000
  3. #define MAX_W 100000
  4. int n, W;
  5. int w[MAX_N], v[MAX_N], s[MAX_N];
  6. int f[MAX_N][MAX_W];
  7. int max(int a, int b) {
  8.     return a > b ? a : b;
  9. }
  10. int min(int a, int b) {
  11.     return a < b ? a : b;
  12. }
  13. int main() {
  14.     scanf("%d %d", &n, &W);
  15.     for (int i = 0; i < n; i++) {
  16.         scanf("%d %d %d", &w[i], &v[i], &s[i]);
  17.     }
  18.     for (int i = 0; i < n; i++) {
  19.         for (int j = W; j >= w[i]; j--) {
  20.             f[i][j] = max(f[i][j], f[i - 1][j - w[i]] + v[i]);
  21.         }
  22.     }
  23.     printf("%d\n", f[n - 1][W]);
  24.     return 0;
  25. }

在这个例子中,输入包括物品的数量n和背包的总容量W,然后是每个物品的重量w[i],价值v[i]和数量s[i]。在这个版本的背包问题中,每个物品可以取多次。f[i][j]表示在容量为j的背包中,前i个物品能够获得的最大价值。程序最后输出的是在给定背包容量下,所有物品的最大价值。

背包问题的贪心算法主要是针对0-1背包问题,即每种物品都有固定数量,可以选择拿或者不拿,但不可以拿走部分。贪心算法的策略是在每一步选择中都采取在当前状态下最好或最优(即最有利)的选择,从而希望导致结果是最好或最优的。

在背包问题中,我们通常用动态规划来求解。在上述代码中,我们用f[i][j]表示前i个物品在容量为j的背包中能够获得的最大价值。初始状态是f[0][j] = 0,表示不取任何物品时的价值为0。然后我们依次考虑每个物品,对于每个物品,我们都尝试放入背包中,并更新f[i][j]。

对于每个物品i,我们从背包容量W开始考虑,逐步减小背包容量,直到背包容量小于物品i的重量。在这个过程中,我们希望找到一个最小的背包容量,使得放入物品i后能够获得最大的价值。这个最小的背包容量就是f[i - 1][j - w[i]],表示前i - 1个物品在容量为j - w[i]的背包中能够获得的最大价值。如果我们将物品i放入容量为j - w[i]的背包中,那么这个背包的容量就增加了w[i],所以能够获得的最大价值就是f[i - 1][j - w[i]] + v[i]。

因此,我们可以得到状态转移方程:f[i][j] = max(f[i][j], f[i - 1][j - w[i]] + v[i])。这个状态转移方程表示,对于前i个物品在容量为j的背包中能够获得的最大价值f[i][j],要么是前i个物品在容量为j的背包中能够获得的最大价值f[i][j],要么是前i - 1个物品在容量为j - w[i]的背包中能够获得的最大价值f[i - 1][j - w[i]] + v[i]。

最后,输出f[n - 1][W],表示前n个物品在容量为W的背包中能够获得的最大价值。

除了上述的贪心算法外,还有一种称为“完全背包”的贪心算法,适用于物品数量不固定的情况。

在完全背包问题中,每种物品的数量是无限的,可以选择拿或者不拿,但不可以拿走部分。以下是一个用C语言实现的完全背包问题的贪心算法:

  1. #include <stdio.h>
  2. #define MAX_N 1000
  3. #define MAX_W 100000
  4. int n, W;
  5. int w[MAX_N], v[MAX_N];
  6. int f[MAX_N][MAX_W];
  7. int max(int a, int b) {
  8.     return a > b ? a : b;
  9. }
  10. int min(int a, int b) {
  11.     return a < b ? a : b;
  12. }
  13. int main() {
  14.     scanf("%d %d", &n, &W);
  15.     for (int i = 0; i < n; i++) {
  16.         scanf("%d %d", &w[i], &v[i]);
  17.     }
  18.     for (int i = 0; i < n; i++) {
  19.         for (int j = w[i]; j <= W; j++) {
  20.             f[i][j] = max(f[i][j], f[i - 1][j - w[i]] + v[i]);
  21.         }
  22.     }
  23.     printf("%d\n", f[n - 1][W]);
  24.     return 0;
  25. }

在这个例子中,输入包括物品的数量n和背包的总容量W,然后是每个物品的重量w[i]和价值v[i]。在这个版本的背包问题中,每种物品的数量是无限的,可以选择拿或者不拿,但不可以拿走部分。我们用f[i][j]表示前i个物品在容量为j的背包中能够获得的最大价值。程序最后输出的是在给定背包容量下,所有物品的最大价值。

在完全背包问题中,由于每种物品的数量是无限的,所以可以将每个物品看作是一个整体,而不必考虑其数量。因此,我们可以将每个物品的重量和价值看作是其整体的“单位重量”和“单位价值”。

在贪心算法中,我们采取的策略是在每一步选择中都采取在当前状态下最好或最优(即最有利)的选择,从而希望导致结果是最好或最优的。因此,我们可以将每个物品的单位价值除以单位重量得到一个“性价比”,然后按照性价比从高到低的顺序依次考虑每个物品。

具体实现时,我们可以先计算每个物品的单位重量和单位价值,然后按照单位价值的降序排列每个物品。对于每个物品,我们可以依次将其加入背包中,并更新背包的容量和价值。这个过程中需要用到一个二维数组f[i][j],表示前i个物品在容量为j的背包中能够获得的最大价值。

状态转移方程与上面的背包问题类似,可以用以下公式表示:

f[i][j] = max(f[i][j], f[i - 1][j - w[i]] + v[i])其中w[i]表示第i个物品的重量,v[i]表示第i个物品的价值。

最后输出f[n - 1][W],表示前n个物品在容量为W的背包中能够获得的最大价值。

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

大数据项目——基于Django/协同过滤算法的房源可视化分析推荐系统的设计与实现

大数据项目——基于Django/协同过滤算法的房源可视化分析推荐系统的设计与实现 技术栈&#xff1a;大数据爬虫/机器学习学习算法/数据分析与挖掘/大数据可视化/Django框架/Mysql数据库 本项目基于 Django框架开发的房屋可视化分析推荐系统。这个系统结合了大数据爬虫、机器学…

递增三元组

遍历三层循环,数据量十分地大,可以找第一行小于第二行的 再找第三行大于第二行的,所有方案的和 通过分析测试样例,111,222,333这三个数存在重复计算。可以想办法存一下每个数的出现次数 如果是111666999.不管1和9怎么变,只要第一行小于6,第二行小于9,答案不变 所以可以想办法存…

如何使用 Oracle SQL Developer 连接 pgvector

如何使用 Oracle SQL Developer 连接 pgvector 1. 下载 postgresql 的 jdbc 驱动2. Oracle SQL Developer 配置第三方驱动3. Oracle SQL Developer 配置 postgres 连接 1. 下载 postgresql 的 jdbc 驱动 访问 https://jdbc.postgresql.org/download/&#xff0c;下载驱动&…

力扣刷题day3(移除元素,找出字符串中的第一个不匹配项的下标,搜索插入位置)

题目1&#xff1a;27.移除元素 思路1和代码&#xff1a; //由于题目要求删除数组中等于 val\textit{ val }val 的元素&#xff0c;因此输出数组的长度一定小于等于输入数组的长度&#xff0c;我们可以把输出的数组直接写在输入数组上。可以使用双指针&#xff1a;右指针 righ…

使用Tomcat部署静态项目并处理BUG

--听讲的习惯 Tomcat介绍 tomcat what_Arenaschi的博客-CSDN博客 Tomcat安装及配置教程&#xff08;超详细&#xff09; 那些年我们用过的tomcat_Arenaschi的博客-CSDN博客 简单使用tomcat查看版本信息等_windows查看tomcat版本命令-CSDN博客 Tomcat部署html静态网站的五种方…

银河麒麟安装lnmp,安装chrome。

安装lnmp 下载相关文件 链接&#xff1a;https://pan.baidu.com/s/1YqFLfGpE5DP3Sf_2GsXqNg?pwdptsn –来自百度网盘超级会员V7的分享 上传到服务器 我所选择上传的地方是 /home/npf/nginx-server&#xff0c; php放在跟nginx-server的同级目录 cd / mkdir home /home/npf…

水库大坝安全监测参数与设备

智慧水利中&#xff0c;水库大坝的安全监测必不可少。做好水库大坝的安全监测&#xff0c;是确保水库大坝结构安全和预防灾害的重要手段。对于预防灾害、保护人民生命财产安全、优化工程管理、改进工程设计、保护环境资源和提高公众信任等方面有着重要的意义。 水利水库大坝安全…

CSS、JS文件无法正确加载至页面问题与解决

目录 1. 问题出现 2. 分析与解决 3. 总结 1. 问题出现 自己在写项目是时候&#xff0c;想启动浏览器查询首页面index.jsp的显示效果 预期效果应该是下面这样的&#xff1a; 但是实际上是这样的&#xff1a; 意思也就是说可能是关于CSS、JS相关的引入方面出了问题&#xff…

创建vue项目:vue脚手架安装、vue-cli安装,vue ui界面创建vue工程(vue2/vue3),安装vue、搭建vue项目开发环境(保姆级教程二)

今天讲解 Windows 如何利用脚手架创建 vue 工程&#xff0c;以及 vue ui 图形化界面搭建 vue 开发环境&#xff0c;这是这个系列的第二章&#xff0c;有什么问题请留言&#xff0c;请点赞收藏&#xff01;&#xff01;&#xff01; 文章目录 1、安装vue-cli脚手架2、vue ui创建…

python 涉及opencv mediapipe知识,眨眼计数 供初学者参考

基本思路 我们知道正面侦测到人脸时&#xff0c;任意一只眼睛水平方向上的两个特征点构成水平距离&#xff0c;上下两个特征点构成垂直距离 当头像靠近或者远离摄像头时&#xff0c;垂直距离与水平距离的比值基本恒定 根据这一思路 当闭眼时 垂直距离变小 比值固定小于某一个…

火狐,要完了!

在过去几年中&#xff0c;关于Firefox 浏览器的衰落有过不少讨论。目前来说&#xff0c;很多公共的以及私营的大型网站都缺乏对Firefox的适当支持。但是Firefox也多次试图“自救”&#xff0c;甚至就在不久前&#xff0c;Mozilla 通过官博发文&#xff0c;表示 Firefox 在 2023…

如何使用Matlab完成窗口与子窗口

目录 一、前言 二、主窗口与主窗口按钮 三、子窗口 四、调用函数并显示在子窗口中的文本框中 五、关闭子窗口 一、前言 有时候需要借用Matlab完成一个图窗功能&#xff0c;但是我们的程序不仅拥有功能&#xff0c;还拥有一些子功能&#xff0c;那么我们该如何借助Matlab完…

[linux] 用命令行wget下载google drive的大文件

使用wget命令下载Google drive上的文件_ubuntu上wget下载谷歌云盘文件-CSDN博客 如何用命令行下载Google Drive上的共享文件&#xff1f;-腾讯云开发者社区-腾讯云 举例&#xff1a;https://drive.google.com/drive/folders/1vKj3VvJEKgS_o-uOSmz3I0-GomECpql3 1、在网页上&…

360压缩安装一半不动了怎么办?

360压缩软件是我们常用的压缩软件&#xff0c;但是常常会遇到压缩安装到一半停止的情况&#xff0c;下面提供了一些可能的原因和解决办法&#xff0c;大家可以进行尝试~ 方法一&#xff1a;关闭防火墙和杀毒软件 有时候&#xff0c;防火墙和杀毒软件可能会阻止360压缩的安装过…

CSM2433 一款集成2.4G+125K 和8位RISC 的SOC芯片

CSM2433是一款集成2.4GHz频段发射器、125KHz接收器和8位RISC&#xff08;精简指令集&#xff09;MCU的SOC芯片。 无线收发器特性&#xff1a; 发射工作在 2.4GHz ISM 频段 发射兼容 BLE 4.2 接收工作在 15KHz-150KHz 内置 32 次可编程 NVM 存储器 3.3V 编程电压 集成低电…

RocketMQ-RocketMQ高性能核心原理与源码剖析(中)

二.小试牛刀阶段 ​ 开始理解一些比较简单的业务逻辑 3、Netty服务注册框架 1、关注重点 ​ 网络通信服务是构建分布式应用的基础&#xff0c;也是我们去理解RocketMQ底层业务的基础。这里就重点梳理RocketMQ的这个服务注册框架&#xff0c;理解各个业务进程之间是如何进行…

Python----多态

1、什么是多态 多态指的是一类事物有多种形态。 定义&#xff1a;多态是一种使用对象的方式&#xff0c;子类重写父类方法&#xff0c;调用不同子类对象的相同父类方法&#xff0c;可以产生不同的执行结果。 ① 多态依赖继承 ② 子类方法必须要重写父类方法 首先定义一个父类…

2.1 网络编程-多用户通信系统(用户登录、拉取在线用户、无异常退出)

文章目录 一、多用户通信系统1.1 介绍1.2 公共类1.2.1 封装消息类1.2.2 用户类1.2.3 消息类型类1.2.4 控制台读取内容 二、用户登录2.1 客户端2.1.1 菜单界面 QQView2.1.2 验证用户UserClientService2.1.3 线程类 ClientConnectServerThread2.1.4 线程集合类 2.2 服务端2.2.1 服…

【面试经典150 | 二叉树】从前序与中序遍历序列构造二叉树

文章目录 写在前面Tag题目来源题目解读解题思路方法一&#xff1a;递归 写在最后 写在前面 本专栏专注于分析与讲解【面试经典150】算法&#xff0c;两到三天更新一篇文章&#xff0c;欢迎催更…… 专栏内容以分析题目为主&#xff0c;并附带一些对于本题涉及到的数据结构等内容…

Jest与typescript单元测试

文章目录 前言安装配置.vscode/launch.jsonjest.config.tsts.config.ts 测试例子 前言 简单记录一下vscode里跑Jest单元测试。 安装 yarn add -D ts-jest ts-node types/jest jest 配置 .vscode/launch.json {"version": "0.2.0","configurations…