算法设计-动态规划法解背包问题 C代码

给大家推荐一个公众号:诗葵1931

里面的诗歌很美

在这里插入图片描述

主要功能:动态规划法解背包问题

#include<stdio.h>  
  
int f[10][100];  
//构造最优矩阵  
void package0_1(int *w,int *v,int n,int c)  
{  
    int i,j;  
    //初始化矩阵  
    for(i=1;i<=n;i++)  
        f[i][0] = 0;  
    for(j=1;j<=c;j++)  
        f[0][j] = 0;      
      
    for(i=1;i<=n;i++)  
    {  
        for(j=1;j<=c;j++)  
        {  
            //当容量够放入第i个物品,并且放入之后的价值要比不放大  
            if(w[i] <= j && f[i-1][j-w[i]] + v[i] > f[i-1][j])  
            {  
                f[i][j] = f[i-1][j-w[i]] + v[i];              
            }else  
                f[i][j] = f[i-1][j];  
        }  
    }     
    printf("最大价值: %d \n",f[n][c]);  
}  
  
//构造最优解  
void getResult(int n,int c,int *res,int *v,int *w)  
{  
    int i,j;  
    j = c;  
    for(i=n;i>=1;i--)  
    {  
        if(f[i][j] != f[i-1][j])  
        {  
            res[i] = 1;  
            j = j - w[i];  
        }  
    }  
}  
  
int main() 
{	printf("物品个数为:5\n"); 
	printf("每个物品的重量:2,2,6,5,4\n");
	printf("每个物品的价值:6,3,5,4,6\n");
	printf("背包能容的重量为:10\n"); 
    int w[6] = {0,2,2,6,5,4};//每个物品的重量  
    int v[6] = {0,6,3,5,4,6};//每个物品的价值  
    int res[5] = {0,0,0,0,0};  
    int n = 5; //物品的个数  
    int c = 10; //背包能容的重量  
    int i,j;  
    package0_1(w,v,n,c);  
    for(i=0;i<=n;i++)  
    {  
        for(j=0;j<=c;j++)  
            printf("%2d ",f[i][j]);  
        printf("\n");  
    }  
    getResult(n,c,res,v,w);  
    printf("放入背包的物品为: \n");  
    for(i=1;i<=n;i++)  
        if(res[i] == 1)  
            printf("%d  ",i);  
}  

我想能看到这里的同学,无外乎两种人:来拷贝代码的人 和 来拷贝代码的人。

但,在拷贝走的时候,你要想清楚一件事,把代码拷走之后有个蛋用,搞明白对你来说才是最重要的。

好了,就酱紫。

老铁,这要是都不赞,说不过去吧!!!

最后对自己说:
你现在所遭遇的每一个不幸,都来自一个不肯努力的曾经。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值