六、全局约束中的Alldifferent和Cumulative的实现

2023-11-02 07:10

本文主要是介绍六、全局约束中的Alldifferent和Cumulative的实现,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

文章目录

  • 1、Alldifferent的内部实现
    • 1.1 防御怪物问题
    • 1.2 Alldifferent 值域传播器
  • 2、Cumulative的内部实现
  • THE END

1、Alldifferent的内部实现

1.1 防御怪物问题

\qquad 假设有 N N N个村庄和 K K K支军队,且满足 K ≥ N K \geq N KN,每支军队都与某些村庄相邻且能够保护他们;一直军队在任一时刻只能保护一个村庄;随机选择一个村庄被袭击,随机选择一个相邻的军队来保护这个村庄,如何调整军队中的职责分配,来保证其他所有村庄在被同时攻击时得到保护?
在这里插入图片描述

\qquad 一个全局约束实现出来之后就是一个全局的传播器,一个好的全局约束应该具备传播强度大,快速传播的特点。通常来说,全局约束传播器都不是幂等的,即调用一遍之后,之后再进行调用时仍可以将变量的数量进行减少。

1.2 Alldifferent 值域传播器

\qquad 抽象出一个Alldifferent值域传播的例子如下图所示:
在这里插入图片描述
\qquad 希望通过Alldifferent值域传播器得到如下结果:
在这里插入图片描述

  • 第一步,贪心匹配
    \qquad 从一个给定的部分匹配开始,选择一个未匹配的变量,直到没有替代方案可以选择为止。
    在这里插入图片描述
  • 第二步,搜索一条交替路径
    \qquad 从未匹配的变量出发,寻找一条未被匹配的边,之后再寻找一条匹配的边,令未被匹配的边和匹配的边交替出现,最终到达一个未匹配的数值,则找到一个最大匹配
    在这里插入图片描述
    \qquad 如上图所示,交替路径为 Y → 3 → Z → 2 → T → 5 Y→3→Z→2→T→5 Y3Z2T5,最终令未匹配的变量 Y Y Y达到匹配状态。
  • 第三步,边定向
    \qquad 对于匹配的边,从变量到数值;对于未匹配的边,从数值到变量。
    在这里插入图片描述
  • 第四步,修剪
    \qquad 保留能够从未匹配数值节点到达的边(粉色+绿色的边)
    \qquad 保留在强连通分量(SCC)中的边(蓝色的边)
    \qquad 保留已经处于最大匹配中的边(黑色的实线边)
    \qquad 删除剩余的边(虚线边)
    在这里插入图片描述
    \qquad 最终得到的结果如下所示:
    在这里插入图片描述
    \qquad Alldifferent全局传播器的时间复杂度为 O ( n 2.5 ) O(n^{2.5}) O(n2.5),基于最大匹配,值域改变事件发生时被调用。

2、Cumulative的内部实现

\qquad 给定 N N N个部队,每个部队都有各自的宽度和穿过城门持续的时间如下所示:
在这里插入图片描述
\qquad 要求限时30min所有部队均进入城镇;不同部队可以同时穿越城门,但是宽度不能超过城门的宽度限制;骑兵需要在物资马车之前进入城镇。问题是对于一个不对,什么时候应该待命给出更好的预估,使得步兵知道他们何时可以休息?(任务调度问题)
\qquad cumulative传播器的数学抽象表达为:
在这里插入图片描述
\qquad 即有 n n n个任务需要进行调度,每一个任务有起始时间 S i S_i Si和持续时间 D i D_i Di,且每个任务执行时需要 R i R_i Ri个单元的某个资源。这个资源在任意时刻最多有 L L L个单元可以使用。当前没有一个实现最强的边界或者值域传播器。这个任务调度问题可以转化为一个二维装箱问题进行处理,如下所示:
在这里插入图片描述
\qquad cumulative基于时间表的传播器的运作流程:首先需要确定一个任务必须在运行的部分;之后需要在资源负荷里面增加这些部分;最后利用已知的负荷来调整其他的任务;如下一个示例:
在这里插入图片描述
\qquad 一个任务的必要部分指的是任务最早完成时间和最晚开始时间之间的时间差值,如下所示:
在这里插入图片描述
\qquad 负荷指的是所有任务必要部分的累和。
在这里插入图片描述
在这里插入图片描述
\qquad cumulative除了基于时间表的传播器的传播器,还可以设计基于分解的传播器,如下所示,但是基于分解的传播器的时间复杂度要高很多:
在这里插入图片描述

THE END

这篇关于六、全局约束中的Alldifferent和Cumulative的实现的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/328972

相关文章

SQL中的外键约束

外键约束用于表示两张表中的指标连接关系。外键约束的作用主要有以下三点: 1.确保子表中的某个字段(外键)只能引用父表中的有效记录2.主表中的列被删除时,子表中的关联列也会被删除3.主表中的列更新时,子表中的关联元素也会被更新 子表中的元素指向主表 以下是一个外键约束的实例展示

hdu1043(八数码问题,广搜 + hash(实现状态压缩) )

利用康拓展开将一个排列映射成一个自然数,然后就变成了普通的广搜题。 #include<iostream>#include<algorithm>#include<string>#include<stack>#include<queue>#include<map>#include<stdio.h>#include<stdlib.h>#include<ctype.h>#inclu

【C++】_list常用方法解析及模拟实现

相信自己的力量,只要对自己始终保持信心,尽自己最大努力去完成任何事,就算事情最终结果是失败了,努力了也不留遗憾。💓💓💓 目录   ✨说在前面 🍋知识点一:什么是list? •🌰1.list的定义 •🌰2.list的基本特性 •🌰3.常用接口介绍 🍋知识点二:list常用接口 •🌰1.默认成员函数 🔥构造函数(⭐) 🔥析构函数 •🌰2.list对象

【Prometheus】PromQL向量匹配实现不同标签的向量数据进行运算

✨✨ 欢迎大家来到景天科技苑✨✨ 🎈🎈 养成好习惯,先赞后看哦~🎈🎈 🏆 作者简介:景天科技苑 🏆《头衔》:大厂架构师,华为云开发者社区专家博主,阿里云开发者社区专家博主,CSDN全栈领域优质创作者,掘金优秀博主,51CTO博客专家等。 🏆《博客》:Python全栈,前后端开发,小程序开发,人工智能,js逆向,App逆向,网络系统安全,数据分析,Django,fastapi

让树莓派智能语音助手实现定时提醒功能

最初的时候是想直接在rasa 的chatbot上实现,因为rasa本身是带有remindschedule模块的。不过经过一番折腾后,忽然发现,chatbot上实现的定时,语音助手不一定会有响应。因为,我目前语音助手的代码设置了长时间无应答会结束对话,这样一来,chatbot定时提醒的触发就不会被语音助手获悉。那怎么让语音助手也具有定时提醒功能呢? 我最后选择的方法是用threading.Time

Android实现任意版本设置默认的锁屏壁纸和桌面壁纸(两张壁纸可不一致)

客户有些需求需要设置默认壁纸和锁屏壁纸  在默认情况下 这两个壁纸是相同的  如果需要默认的锁屏壁纸和桌面壁纸不一样 需要额外修改 Android13实现 替换默认桌面壁纸: 将图片文件替换frameworks/base/core/res/res/drawable-nodpi/default_wallpaper.*  (注意不能是bmp格式) 替换默认锁屏壁纸: 将图片资源放入vendo

C#实战|大乐透选号器[6]:实现实时显示已选择的红蓝球数量

哈喽,你好啊,我是雷工。 关于大乐透选号器在前面已经记录了5篇笔记,这是第6篇; 接下来实现实时显示当前选中红球数量,蓝球数量; 以下为练习笔记。 01 效果演示 当选择和取消选择红球或蓝球时,在对应的位置显示实时已选择的红球、蓝球的数量; 02 标签名称 分别设置Label标签名称为:lblRedCount、lblBlueCount

Kubernetes PodSecurityPolicy:PSP能实现的5种主要安全策略

Kubernetes PodSecurityPolicy:PSP能实现的5种主要安全策略 1. 特权模式限制2. 宿主机资源隔离3. 用户和组管理4. 权限提升控制5. SELinux配置 💖The Begin💖点点关注,收藏不迷路💖 Kubernetes的PodSecurityPolicy(PSP)是一个关键的安全特性,它在Pod创建之前实施安全策略,确保P

poj 3159 (spfa差分约束最短路) poj 1201

poj 3159: 题意: 每次给出b比a多不多于c个糖果,求n最多比1多多少个糖果。 解析: 差分约束。 这个博客讲差分约束讲的比较好: http://www.cnblogs.com/void/archive/2011/08/26/2153928.html 套个spfa。 代码: #include <iostream>#include <cstdio>#i

poj 3169 spfa 差分约束

题意: 给n只牛,这些牛有些关系。 ml个关系:fr 与 to 牛间的距离要小于等于 cost。 md个关系:fr 与 to 牛间的距离要大于等于 cost。 隐含关系: d[ i ] <= d[ i + 1 ] 解析: 用以上关系建图,求1-n间最短路即可。 新学了一种建图的方法。。。。。。 代码: #include <iostream>#include