zoukankan      html  css  js  c++  java
  • 01背包问题 南邮NOJ 1308

    背包问题

    时间限制(普通/Java) : 1000 MS/ 3000 MS          运行内存限制 : 65536 KByte
    总提交 : 79            测试通过 : 30 

    题目描述

             试设计一个用回溯法搜索子集空间树的函数。该函数的参数包括结点可行性判定函数和上界函数等必要的函数,并将此函数用于解0-1背包问题。

    0-1 背包问题描述如下:给定种物品和一个背包。物品的重量是 wi ,其价值为 v i,背包的容量为C。应如何选择装入背包的物品,使得装入背包中物品的总价值最大?

    在选择装入背包的物品时,对每种物品i只有种选择,即装入背包或不装入背包。不能将物品装入背包多次,也不能只装入部分的物品i

    0-1 背包问题形式化描述:给定C0, Wi 0 Vi 01in,要求0-1向量 x1 x2 ,…, xn )xi01},1in,使得                  达到最大



    输入

     第一行有2个正整数ncn是物品数,c是背包的容量。接下来的行中有n个正整数,表示物品的价值。第行中有n个正整数,表示物品的重量。

    输出

     计算出装入背包物品的最大价值和最优装入方案。

    样例输入

    5 10
    6 3 5 4 6
    2 2 6 5 4

    样例输出

    15
    1 1 0 0 1

    提示

     

    典型的01背包问题,实现代码如下:

    #include<iostream>
    #include<cstdlib>
    #include<cstdio>
    #include<algorithm>
    using namespace std;
    int V[200][200];//前i个物品装入容量为j的背包中获得的最大价值
    int max(int a,int b)
    {
       if(a>=b)
           return a;
       else return b;
    }
    
    int KnapSack(int n,int w[],int v[],int x[],int C)
    {
        int i,j;
        for(i=0;i<=n;i++)
            V[i][0]=0;
        for(j=0;j<=C;j++)
            V[0][j]=0;
        for(i=0;i<=n-1;i++)
            for(j=0;j<=C;j++)
                if(j<w[i])
                    V[i][j]=V[i-1][j];
                else
                    V[i][j]=max(V[i-1][j],V[i-1][j-w[i]]+v[i]);
                j=C;
                for(i=n-1;i>=0;i--)
                {
                    if(V[i][j]>V[i-1][j])
                    {
                    x[i]=1;
                    j=j-w[i];
                    }
                else
                    x[i]=0;
                }
            return V[n-1][C];
    
    }
    
    int main()
    {
        int s;//获得的最大价值
        int w[15];//物品的重量
        int v[15];//物品的价值
        int x[15];//物品的选取状态
        int n,i;
        int C;//背包最大容量
        int sum=0;
        n=5;
        scanf("%d%d",&n,&C);
         for(i=0;i<n;i++)
        {  scanf("%d",&v[i]);
              sum+=v[i];
        }
        for(i=0;i<n;i++)
            scanf("%d",&w[i]);
        s=KnapSack(n,w,v,x,C);
        printf("%d
    ",s);
        for(i=0;i<n;i++)
        {
            if(i==0)
            {
                printf("%d",x[i]);
            }
            else
                printf(" %d",x[i]);
        }
        printf("
    ");
    }

    版权声明:本文为博主原创文章,未经博主允许不得转载。

  • 相关阅读:
    MySQL中查询表及索引大小的方法
    转:一套大而全的系统架构体系与具体落地方案
    [转]1年时间业务量疯长40倍,谈人人车的平台架构演进之路
    [转]如何实现“持续集成”?闲鱼把研发效率翻了个翻
    微服务介绍
    Python2.X和Python3.X的w7同时安装使用
    黑客与画家阅读体会
    Open Source 开发工具集
    volatile和不加volatile的区别
    VMware改变硬盘空间大小的方法
  • 原文地址:https://www.cnblogs.com/Tobyuyu/p/4965593.html
Copyright © 2011-2022 走看看