算法练习-NOJ-1004-01背包问题

时限:1000ms 内存限制:10000K 总时限:3000ms

描述

需对容量为c 的背包进行装载。从n 个物品中选取装入背包的物品,每件物品i 的重量为wi ,价值为pi 。对于可行的背包装载,背包中物品的总重量不能超过背包的容量,最佳装载是指所装入的物品价值最高。

输入

多个测例,每个测例的输入占三行。第一行两个整数:n(n<=10)和c,第二行n个整数分别是w1到wn,第三行n个整数分别是p1到pn。
n 和 c 都等于零标志输入结束。

输出

每个测例的输出占一行,输出一个整数,即最佳装载的总价值。

输入样例

1 2
1
1
2 3
2 2
3 4
0 0

输出样例

1
4

#include <stdio.h>
#include <Windows.h>

void search(int);
void checkmax();

int c,n;            //c: 背包容量;n:物品数
int w[100000], v[100000];       //w[i]、v[i]:第i件物品的重量和价值
int a[100000], max, weight=0, value=0;        //a数组存放当前解各物品选取情况;max:记录最大价值
//a[i]=0表示不选第i件物品,a[i]=1表示选第i件物品
int main()
{
    scanf("%d%d",&n,&c);//n个物品,背包容量为c
    while(n!=0||c!=0)
    {
        int i;
        for(i=0;i<n;i++)
        scanf("%d",&w[i]);//每个物品重量
        for(i=0;i<n;i++)
        scanf("%d",&v[i]);//每个物品价值
        search(0);//子集树搜索模式进行搜索
        printf("%d\n",max);

        for(i=0;i<n;i++)
        { 
        w[i]=0;  v[i]=0; a[i]=0;
        }//每个物品重量
    max = 0;
        scanf("%d%d",&n,&c);//n个物品,背包容量为c
    }
    return 0;

}
void search(int m)
{
    if(m>=n)
        checkmax();   //检查当前解是否是可行解,若是则把它的价值与max比较
    else
    {
        a[m]=0;       //不选第m件物品
        search(m+1);  //递归搜索下一件物品
        a[m]=1;       //不选第m件物品
        search(m+1);  //递归搜索下一件物品
    }
}
void checkmax()
{
    weight=0,value=0;
    int i;
    for(i=0;i<n;i++)
    {
        if(a[i]==1)                 //如果选取了该物品
        {
            weight = weight + w[i];  //累加重量
            value = value + v[i];     //累加价值
        }
    }

    if(weight<=c)                  //若为可行解
        if(value>max)              //且价值大于max
            max=value;            //替换max
}
  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值