动态规划C语言

#include <stdio.h>

#include <stdlib.h>

//0-1背包问题是一种经典的组合优化问题,

//问题描述为:有一个给定容量的背包和一组具有不同价值和重量的物品,如何选择物品放入背包中,以使得背包中物品的总价值最大化,同时不超过背包的容量限制。

#define max(a, b) ((a) > (b) ? (a) : (b))

int knapsack(int W, int wt\[\], int val\[\], int n) {//背包函数这是一个名为knapsack的函数,它接受四个参数:

//W:表示背包的总容量。

//wt\[\]:一个整数数组,表示每个物品的重量。

//val\[\]:一个整数数组,表示每个物品的价值。

//n:表示物品的数量。

int i, w;

int Kn+1W+1; // 填充 K()() 数组

for (i = 0; i <= n; i++) {//遍历每个物品

for (w = 0; w <= W; w++) {//遍历背包容量

if (i == 0 || w == 0) {

Kiw = 0;

} else if (wti-1 <= w) {// 如果物品i的重量wti-1小于等于背包容量w,

Kiw = max(vali-1 + Ki-1w-wt\[i-1], Ki-1w);

//可以将物品i放入背包,或者不放入背包。在这两种情况下,选择能够获得更大总价值的方案,并将对应的价值存储在Kiw中。

} else {//如果物品i的重量wti-1大于背包容量w,那么物品i无法放入背包,因此Kiw的值保持不变,即等于Ki-1w

Kiw = Ki-1w;

}

}

}

return KnW;//即表示在给定背包容量和物品重量、价值的情况下,能够装入背包的物品的最大总价值。

}

int main() {

int val\[\] = {60, 100, 120};

int wt\[\] = {10, 20, 30};

int W = 50;

int n = sizeof(val) / sizeof(val0);//物品的数量

printf("背包中能装的最大价值为:%d\n", knapsack(W, wt, val, n));

return 0;

}

相关推荐
剑挑星河月几秒前
31.下一个排列
java·算法·leetcode
凌波粒4 分钟前
LeetCode--98.验证二叉搜索树(二叉树)
算法·leetcode·职场和发展
Ameilide17 分钟前
数据结构 树 二叉树
数据结构
Kurisu57527 分钟前
深度拆解:从令牌桶到滑动窗口,高并发系统限流算法的数学本质与边界
java·网络·算法
哈泽尔都27 分钟前
运动控制教学——5分钟学会力控算法(阻抗/导纳/力位混合)
c++·python·算法·决策树·贪心算法·机器人·gpu算力
WWW652631 分钟前
代码随想录 打卡第四十七天
数据结构·算法·leetcode
1892280486135 分钟前
NV022固态MT29F16T08GWLCEM5-QBES:C
c语言·开发语言
cpp_250136 分钟前
P10722 [GESP202406 六级] 二叉树
数据结构·c++·算法·题解·洛谷·树形结构·gesp六级
smj2302_7968265242 分钟前
解决leetcode第3948题字典序最大的MEX数组
python·算法·leetcode
紫阡星影1 小时前
【STM32CubeMX项目】智能家居门禁系统
c语言·单片机·嵌入式硬件