作业分配问题——分支限界

本文探讨了如何使用分支限界法解决作业分配问题。在n个人完成n份作业的情景下,每人都需完成一份作业,且每个人完成每份作业所需时间cij各不相同。通过广度优先搜索配合优先队列,按特定比较器进行排序,实现有效选择。同时,通过设置限界条件进行剪枝,减少无效分支,优化求解过程。
摘要由CSDN通过智能技术生成

问题描述:有n份作业分配给n个人去完成,每人完成一份作业。假定第i个人完成第j份作业需要花费cij时间, cij>0,1≦i,j≦n。

参考内容

import java.io.BufferedReader;
import java.io.FileReader;
import java.io.IOException;
import java.util.*;

public class Branch_Bound {
    static int[][] cost ;//每个工人执行每项工作所花的时间矩阵记录
    Comparator<Node> comparator = new Comparator<Node>() {//定义比较函数,比较结点的时间花费值
        @Override
        public int compare(Node o1, Node o2) {
            return o1.getLb()-o2.getLb();
        }
    };
    //使用小顶堆二叉树排序实现,根据传入的比较器依据将元素从小到大排序的优先队列
    PriorityQueue<Node> priorityQueue = new PriorityQueue<Node>(comparator);//存储拓展结点的队列
    int results = 0;//记录结果的花费时间
    Node resultNode = null;//存储结果结点

    //程序入口
    public static void main(String[] args) throws IOException {
        System.out.println("请输入要测试的编号:");
        Scanner input = new Scanner(System.in);
        int number = input.nextInt();
        Branch_Bound branchBound = new Branch_Bound();
        branchBound.init(number);//读取数据并初始化矩阵
        Node root = branchBound.initRootNode();//初始化根节点
        branchBound.branch_bound(root);//开始分支限界
        List<Integer> work = branchBound.resultNode.getList();//最终工作分配方案序列
        System.out.println("分配方案:");
        int totalCost = 0;
        for(int i=0;i<cost.length;i++){
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值