算法设计与分析:分支限界法

news2025/1/11 22:50:53

目录

第1关:0/1背包问题

任务描述:

相关知识:

分支限界法基本思想:

常见的分支限界法:

示例:0/1背包问题

对于0/1背包的优化:

题目描述:

编程要求:

测试说明:

第2关:旅行商问题

任务描述:

相关知识:

问题描述:

问题分析:

 编程要求:

测试说明:


第1关:0/1背包问题

任务描述:

本关任务:分支限界法;

相关知识:

为了完成本关任务,你需要掌握:0/1背包问题;

分支限界法基本思想:

分支限界法是求解纯整数规划或混合整数规划问题的经典方法,在上世纪六十年代由Land Doig和Dakin等人提出。这种方法灵活且便于用计算机求解,目前已经成功运用于求解生产进度问题、旅行推销员问题、工厂选址问题、背包问题及分配问题等。算法基本思想如下:

  1. 以广度优先或以最小耗费(最大效益)优先的方式搜索问题的解空间树。
  2. 分支限界法中,每一个活结点只有一次机会成为扩展结点,活结点一旦成为扩展结点,就一次性产生其所有儿子结点,其中导致不可行解或导致非最优解的儿子结点被舍弃,其余儿子结点被加入活结点表中。
  3. 然后从活结点表中取下一结点成为当前扩展结点。
  4. 重复上述结点扩展过程,直至到找到所需的解或活结点表为空时为止。

常见的分支限界法:

队列式分支限界法 按照队列先进先出(FIFO)原则选取下一个结点为扩展结点 从活结点表中取出结点的顺序与加入结点的顺序相同,因此活结点表的性质与队列相同

优先队列分支限界法(代价最小或效益最大) 每个结点都有一个对应的耗费或收益,以此决定结点的优先级 从优先队列中选取优先级最高的结点成为当前扩展结点 如果查找一个具有最小耗费的解:则活结点表可用小顶堆来建立,下一个扩展结点就是具有最小耗费的活结点 如果希望搜索一个具有最大收益的解:则可用大顶堆来构造活结点表,下一个扩展结点是具有最大收益的活结点

示例:0/1背包问题

 

 

 

 

 

 

 

 

 

 

 

 

对于0/1背包的优化:

首先,要对输入数据进行预处理,将各物品依其单位重量价值从大到小进行排列。在优先队列分支限界法中,节点的优先级由已装袋的物品价值加上剩下的最大单位重量价值的物品装满剩余容量的价值和。 算法首先检查当前扩展结点的左儿子结点的可行性。如果该左儿子结点是可行结点,则将它加入到子集树和活结点优先队列中。当前扩展结点的右儿子结点一定是可行结点,仅当右儿子结点满足上界约束时才将它加入子集树和活结点优先队列。当扩展到叶节点时为问题的最优值。

题目描述:

0-1背包问题:给定n种物品和一背包。物品i的重量是wi, 其价值为Vi, 背包的容量为C。问应如何选择装入背包中的物品,使得装入背包中物品的总价值最大?在选择装入背包的物品时,对每种物品i可以选择这个物品的一部分。

编程要求:

根据提示,在右侧编辑器补充代码,树的层次遍历。

输入: 通过文件读入,第一行包括两个整数n和c,代表物品数和背包容量,接下来的n行每行包括两个整数,$w[i]$和$v[i]$代表物品的重量和价值。 输出: 将计算结果输出到文件,包括最优价值和选取方案包括2行,第一行一个整数,表示计算结果,第二行包括一组序列,表示选取方案,按照$T={1,0,1,1}$,矩阵形式表示。要求使用分支限界法求解。

测试说明:

测试输入:

  1. 10 34
  2. 2 15
  3. 8 25
  4. 4 9
  5. 4 9
  6. 8 15
  7. 7 12
  8. 8 12
  9. 5 6
  10. 16 14
  11. 16 9

预期输出:

  1. 85
#include <iostream>
using namespace std;

int maxSize=0;
/********** Begin **********/
void backtrack(int * weights, int * values, int sum, int value, int totalCapacity, int index, int num){
    
    if(value >maxSize){
        maxSize = value;
    }
	if (index>=num) {
        return;
    }
    for (int i = 0; i <= 1; i++) {
        if(sum + weights[index]*i <= totalCapacity){
        	backtrack(weights, values, sum + weights[index] * i, value + values[index] * i, totalCapacity, index + 1, num);
		}
    }
}
 /********** End **********/

int main() {
    /********** Begin **********/
    int n;
    int capacity;

    cin >> n;
    cin >> capacity;
    int* weights = new int[n];
    int* values = new int[n];

    for (int i = 0; i < n; i++) {
        cin >> weights[i];
        cin >> values[i];
    }
    backtrack(weights, values, 0, 0, capacity, 0, n);
    cout << maxSize << endl;
    delete[] weights;
    delete[] values;
    /********** Begin **********/
	return 0;
}

第2关:旅行商问题

任务描述:

本关任务:旅行商问题。

相关知识:

为了完成本关任务,你需要掌握:分支限界法。

问题描述:

某售货员要到若干城市去推销商品,已知各城市之间的路程,他要选定一条从驻地出发,经过每个城市一遍,最后回到住地的路线,使总的路程最短。

 结果为: 1 3 2 4 1

问题分析:

解旅行售货员问题的优先队列式分支限界法用优先队列存储活结点表 活结点m在优先队列中的优先级定义为:活结点m对应的子树费用下界lcostlcost=cc+rcost,其中,cc为当前结点费用,rcost为当前顶点最小出边费用加上剩余所有顶点的最小出边费用和。 优先队列中优先级最大的活结点成为下一个扩展结点。 排列树中叶结点所相应的载重量与其优先级(下界值)相同,即:叶结点所相应的回路的费用(bestc)等于子树费用下界lcost的值。 与子集树的讨论相似,实现对排列树搜索的优先队列式分支限界法也可以有两种不同的实现方式:(旅行售货员问题采用第一种实现方式。)

  1. 用优先队列来存储活结点。优先队列中每个活结点都存储从根到该活结点的相应路径
  2. 用优先队列来存储活结点,并同时存储当前已构造出的部分排列树。优先队列中的活结点不必存储从根到该活结点的相应路径,该路径必要时从存储的部分排列树中获得

 

 编程要求:

根据提示,在右侧编辑器补充代码,计算并输出数组的平均值和最大值。

测试说明:

输入数据: 第一行,有n个城市。 后面n行n列,代表n个城市直接的距离。没联系用-1代替。 输出数据: 一行。最优值,最优解的走法 平台会对你编写的代码进行测试:

平台会对你编写的代码进行测试:

测试输入:

  1. 4
  2. -1 30 6 4
  3. 30 -1 5 10
  4. 6 5 -1 20
  5. 4 10 20 -1

预期输出:

  1. 最优值为:25最优解为:1423

#include <iostream>
#define NO_PATH -1         //没有通路
#define MAX_WEIGHT 4000

using namespace std;
/********** Begin **********/
// 函数,全局变量,结构体等
int N;                     //城市数目
int City_Graph[100][100];  //保存图信息
int x[100];                //x[i]保存第i步遍历的城市
int isIn[100];             //保存 城市i是否已经加入路径
int bestw;                 //最优路径总权值
int cw;                    //当前路径总权值
int bestx[100];            //最优路径
void Travel_Backtrack(int t){        //递归法
    int i,j;
    if(t>N){                         //走完了,输出结果
        if(cw < bestw){              //判断当前路径是否是更优解
            for (i=1;i<=N;i++){
                bestx[i] = x[i];
            }
            bestw = cw+City_Graph[x[N]][1];
        }
        return;
    }
    else{
        for(j=1;j<=N;j++){           //找到第t步能走的城市
            if(City_Graph[x[t-1]][j] != NO_PATH && !isIn[j]){ //能到而且没有加入到路径中
                isIn[j] = 1;
                x[t] = j;
                cw += City_Graph[x[t-1]][j];
                Travel_Backtrack(t+1);
                isIn[j] = 0;
                x[t] = 0;
                cw -= City_Graph[x[t-1]][j];
            }
        }
    }
}
/********** End **********/


int main(){
    /********** Begin **********/
    int i;
    cin>>N;
    for(int i=1;i<=N;i++){
        
        for(int j=1;j<=N;j++){
            cin>>City_Graph[i][j];
        }
    }

    //测试递归法
    for (i=1;i<=N;i++){
        x[i] = 0;               //表示第i步还没有解
        bestx[i] = 0;           //还没有最优解
        isIn[i] = 0;            //表示第i个城市还没有加入到路径中
    }

    x[1] = 1;                   //第一步 走城市1
    isIn[1] = 1;                //第一个城市 加入路径
    bestw = MAX_WEIGHT;
    cw = 0;
    Travel_Backtrack(2);        //从第二步开始选择城市
    cout<<"最优值为:"<<bestw;
    cout<<"最优解为:";
        for(i=1;i<=N;i++){
        cout<<bestx[i];
    }
   cout<<endl;
   /********** End **********/
   return 0;
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/538167.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

chatgpt赋能Python-pycharm中怎么粘贴代码

PyCharm是Python编程领域中最受欢迎的集成开发环境之一。它是由JetBrains开发的一款跨平台IDE软件&#xff0c;旨在优化Python项目的开发过程。PyCharm拥有强大的代码编辑器、调试器、代码跟踪器和内置的版本控制工具&#xff0c;可以帮助开发人员编写高效、优质的Python代码。…

超级详细Git操作 之git log 命令的参数详解

git log命令主要用于查看Git版本演变历史&#xff08;也就是提交历史&#xff09;&#xff0c;同时根据追加的参数和选项不同&#xff0c;也会有不同的展示效果。 但默认git log命令显示出的x效果实在太丑&#xff0c;不好好打扮一下根本没法见人&#xff0c;打扮好了用alias命…

chatgpt赋能Python-pycharm怎么重新配置python环境

Pycharm重新配置Python环境方法概述 如果您是Python编程的专业人士或者是刚开始学习Python&#xff0c;您可能已经听说了Pycharm这个IDE。Pycharm不仅可以提高您Python编程的效率&#xff0c;而且也大大改善了整个开发过程。不过&#xff0c;如果您需要使用Pycharm重新配置Pyt…

深度学习用于医学预后-第二课第四周1-4节随堂作业

作业名&#xff1a;C2_W4_lecture.ipynb 作业地址&#xff1a; github --> bharathikannann/AI-for-Medicine-Specialization-deeplearning.ai --> AI for Medical Prognosis --> Week 4 One-hot encode categorical variables 首先我们来看一下哪些特征是分类特征…

Maven高级篇

分模块开发与设计 ssm_pojo拆分 新建模块拷贝原始项目中对应的相关内容到ssm_pojo模块中 实体类&#xff08;User&#xff09;配置文件&#xff08;无&#xff09; ssm_dao拆分 新建模块拷贝原始项目中对应的相关内容到ssm_dao模块中 数据层接口&#xff08;UserDao&#x…

spring学习笔记(2)

目录 RESTful Web 服务是干啥用的&#xff1f; 这个是什么意思&#xff1f;“OpenJDK 64-Bit Server VM warning: Options -Xverify:none and -noverify were deprecated in JDK 13 and will likely be removed in a future release.” 构建一个RESTful Web服务 GB有多大 点击…

IBM 创新方案+SNP数据转型助一汽大众实现数据平稳、高效迁移

近日&#xff0c;IBM 采用基于SNP Bluefield技术迁移的IBM Rapid Move创新数据迁移方案, 成功为一汽-大众实施了企业运营数据系统从 ECC 到 S/4 的升级项目。该项目系统切换耗时仅三天&#xff0c;不仅助客户高效、平稳迁移了系统数据&#xff0c;升级了数据底座&#xff0c;还…

第六讲:“声音”写具体

爸爸又打呼了!“呼噜一呼噜一像一股巨浪腾空而起&#xff0c;以每秒八十米的速度向上冲刺&#xff0c;力图掀开天花板&#xff0c;掀翻整座住宅楼;“呼噜一一呼噜一-”&#xff0c;像一台轰鸣的坦克在穿行&#xff0c;床垫在抖动&#xff0c;吊灯在摇晃&#xff0c;墙灰在簌籁(…

【办公软件篇】Listary搜索神器清除搜索历史记录

【办公软件篇】Listary搜索神器清除搜索历史记录 装机必备搜索神器—【蘇小沐】 文章目录 【办公软件篇】Listary搜索神器清除搜索历史记录1.实验环境 &#xff08;一&#xff09;删除搜索历史记录总结 1.实验环境 官网地址&#xff1a;Listary Discussions 系统版本Windows…

chatgpt赋能Python-pycharm怎么添加库函数

PyCharm怎么添加库函数 作为一位拥有10年python编程经验的工程师&#xff0c;我可以告诉大家&#xff0c;PyCharm是一个非常优秀的Python集成开发环境&#xff0c;它可以帮助我们更加高效地编写Python代码。但是在使用PyCharm的时候&#xff0c;我们经常需要使用一些库函数&am…

Vue3——简易个人空间(下半部分)

书接上回: 好友列表页面实现: 根据提供的api从云端将10个用户读进来 根据提供的api获得如下的json格式的数据&#xff0c;里面有四个用户的信息。 这里使用ajax进行实现要先在项目中安装jquery&#xff0c;使用命令行安装 npm i jquery然后在用户列表页面要先引入jquery i…

数据结构——插入排序与希尔排序

&#x1f307;个人主页&#xff1a;_麦麦_ &#x1f4da;今日名言&#xff1a;喜你成疾&#xff0c;药石无医。——《玫瑰与鹿》 一、前言 在本篇文章&#xff0c;我们将为小伙伴们进行排序概念的基本讲解并具体讲解其中的两种基础排序&#xff1a;插入排序和希尔排序&#xff…

BSQ格式数据转换为RSD缺省的BIP格式数据

李国春 RSD内部统一以BIP格式排列数据&#xff0c;并且文件格式&#xff08;非TFS&#xff09;数据倒放&#xff08;North Down&#xff09;。早期是为了和设备无关位图&#xff08;DIB&#xff09;一致节省一点处理时间。现在设备处理能力增强了这点时间已经无关紧要&#xf…

目标检测复盘 -- 1.mAP及其他评价指标

前言 为什么想单独做一个目标检测篇&#xff0c;主要是感觉自己是个半吊子&#xff0c;满瓶不响、半瓶晃荡&#xff0c;找工作的过程中&#xff0c;也被很多面试官问到哑口无言&#xff0c;基础真的不扎实&#xff0c;自己非常虚&#xff0c;想好好地、静下心来捋一下&#xf…

Linux环境搭建及问题解决方案

本文介绍了Linux环境搭建的过程以及遇到的问题和解决方案&#xff0c;并且介绍了常用的Linux命令. 一、Linux环境搭建 整体所需的环节 安装VMware安装Linux &#xff08;这边我选的是Server版本&#xff09;安装配置Samba&#xff08;Samba是一种Linux和Windows之间进行文件共…

基础知识(王爽老师书第一章)

文章目录 基础知识1.1 引言1.2 机器语言1.2 引言汇编语言的产生1.3 汇编语言的组成1.4 存储器1.5 指令和数据1.6 存储单元1.7 CPU对存储器的读写1.8 地址总线1.9 数据总线1.10 控制总线小结检测点1.11.11 内存地址空间1.12 主板1.13 接口卡1.14 各类存储器芯片1.15 内存地址空间…

【Linux】在Ubuntu中下载jdk以及卸载oraclejdk

介绍 这里是小编成长之路的历程&#xff0c;也是小编的学习之路。希望和各位大佬们一起成长&#xff01; 以下为小编最喜欢的两句话&#xff1a; 要有最朴素的生活和最遥远的梦想&#xff0c;即使明天天寒地冻&#xff0c;山高水远&#xff0c;路远马亡。 一个人为什么要努力&a…

短视频矩阵系统源码/开发技术文档

短视频矩阵系统技术文档&#xff1a; 可以采用电子文档或者纸质文档的形式交付&#xff0c;具体取决于需求方的要求。电子文档可以通过电子邮件、远程指导交付云存储等方式进行传输、 短视频矩阵{seo}源码是指将抖音平台上的视频资源进行筛选、排序等操作&#xff0c;进而提升…

【AcWing刷题】蓝桥杯专题突破-动态规划-dp入门(17)

目录 写在前面&#xff1a; 题目&#xff1a;821. 跳台阶 - AcWing题库 题目描述&#xff1a; 输入格式&#xff1a; 输出格式&#xff1a; 数据范围&#xff1a; 输入样例&#xff1a; 输出样例&#xff1a; 解题思路&#xff1a; 方法一&#xff1a;暴力搜索 代码…

chatgpt赋能Python-pandas_归一化

Pandas归一化是什么&#xff1f; 数据归一化是数据预处理中的一个重要步骤&#xff0c;它能够将不同范围的数值转化为相同的数值范围。Pandas是一种数据处理工具&#xff0c;因此它提供了许多函数来实现数据归一化。其中最常用的函数是Normalization。 Normalization函数的使…