0-1背包问题分支定限法Java实现

本文由此博客更改而来,对此博客的解法进行了部分修改,代码结构尚有很多不足之处,敬请原谅~

具体实现请看代码及其注释:

定义的一个节点对象,封装v与w等信息,将被作为二叉树节点使用

class ItemNode implements Comparable<ItemNode>{
     
    int weight;//该节点目前背包中的重量  
    double value;//该节点目前背包中的总价值  
    double upprofit;//该节点能够达到的价值上界  
    int selected;   //该节点是否属于左节点(用于最终构造最优解)  
    int level;  //该节点是第几个物品的选择  
    int index;
    ItemNode parent; //该节点的父节点  
    public int compareTo(ItemNode node){  
        if(this.upprofit<node.upprofit)  
            return 1;  
        else if(this.upprofit == node.upprofit)  
            return 0;  
        else  
            return -1;  
    }  
}  

定义算法对象

public class AlgorithmFor01Bag {  
    int n = 5;
    int capacity = 10;
    int[] weight = { 2, 6, 4, 1, 5 };
    double[] value = { 6, 9, 6, 1, 4
  • 0
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值