运筹优化学习16:【电招问题】Dial-a-Ride问题模型及C#实现的VNS程序

简介: 运筹优化学习16:【电招问题】Dial-a-Ride问题模型及C#实现的VNS程序

1 DARP

1.1 问题描述

有k辆容量不同的汽车,为一组包含起点和终点运输需求的顾客提供运输服务。

定义节点集合gif.gif,前n个节点为起点、后n个节点为目的地

弧段集合:gif.gif

对于弧段gif.gif有运输成本gif.gif和旅行时间gif.gif

节点具有出发时间窗gif.gif,和抵达时间窗gif.gif

具有需求量gif.gif

当顾客i被车辆j拾取时,产生成本gif.gif

卡车返回车场的最晚时间gif.gif

1.2 约束条件


每辆卡车从车场出发并最终返回,每个车辆访问每个弧段仅一次

gif.gif必须在gif.gif之前

任一点的gif.gif不大于车辆容量

出发和抵达时间窗必须被满足


所有车辆在T之前返回


1.3 目标函数

考虑运输成本和顾客偏好的成本最小

2 手算示例


20191202104202637.png

2019120210435913.png

2019120210430835.png

3 C#的实现

3.1 数据准备


20191202104612328.png20191202104855446.png


3.2 程序调用

exe路径:"F:\darp.exe"

算例文件路径:"F:\genIns.darp"

20191202110054527.png

可执行文件点这里启发式算法,结果并不稳定

20191202110910679.png





相关文章
|
2月前
|
Java 物联网 C#
C#/.NET/.NET Core学习路线集合,学习不迷路!
C#/.NET/.NET Core学习路线集合,学习不迷路!
|
3月前
|
缓存 C# Windows
C#程序如何编译成Native代码
【10月更文挑战第15天】在C#中,可以通过.NET Native和第三方工具(如Ngen.exe)将程序编译成Native代码,以提升性能和启动速度。.NET Native适用于UWP应用,而Ngen.exe则通过预编译托管程序集为本地机器代码来加速启动。不过,这些方法也可能增加编译时间和部署复杂度。
179 2
|
26天前
|
缓存 API C#
C# 一分钟浅谈:GraphQL 优化与性能提升
本文介绍了 GraphQL API 的常见性能问题及优化方法,包括解决 N+1 查询问题、避免过度取数据、合理使用缓存及优化解析器性能,提供了 C# 实现示例。
71 33
|
28天前
|
算法 Java 测试技术
Benchmark.NET:让 C# 测试程序性能变得既酷又简单
Benchmark.NET是一款专为 .NET 平台设计的性能基准测试框架,它可以帮助你测量代码的执行时间、内存使用情况等性能指标。它就像是你代码的 "健身教练",帮助你找到瓶颈,优化性能,让你的应用跑得更快、更稳!希望这个小教程能让你在追求高性能的路上越走越远,享受编程带来的无限乐趣!
86 13
|
3月前
|
设计模式 程序员 C#
C# 使用 WinForm MDI 模式管理多个子窗体程序的详细步骤
WinForm MDI 模式就像是有超能力一般,让多个子窗体井然有序地排列在一个主窗体之下,既美观又实用。不过,也要小心管理好子窗体们的生命周期哦,否则一不小心就会出现一些意想不到的小bug
262 0
|
3月前
|
开发框架 缓存 算法
开源且实用的C#/.NET编程技巧练习宝库(学习,工作,实践干货)
开源且实用的C#/.NET编程技巧练习宝库(学习,工作,实践干货)
|
3月前
|
XML 存储 安全
C#开发的程序如何良好的防止反编译被破解?ConfuserEx .NET混淆工具使用介绍
C#开发的程序如何良好的防止反编译被破解?ConfuserEx .NET混淆工具使用介绍
134 0
|
4月前
|
C# 容器
C#中的命名空间与程序集管理
在C#编程中,`命名空间`和`程序集`是组织代码的关键概念,有助于提高代码的可维护性和复用性。本文从基础入手,详细解释了命名空间的逻辑组织方式及其基本语法,展示了如何使用`using`指令访问其他命名空间中的类型,并提供了常见问题的解决方案。接着介绍了程序集这一.NET框架的基本单位,包括其创建、引用及高级特性如强名称和延迟加载等。通过具体示例,展示了如何创建和使用自定义程序集,并提出了针对版本不匹配和性能问题的有效策略。理解并善用这些概念,能显著提升开发效率和代码质量。
152 4
|
3月前
|
安全 API C#
C# 如何让程序后台进程不被Windows任务管理器强制结束
C# 如何让程序后台进程不被Windows任务管理器强制结束
82 0
|
3月前
|
API C#
C#实现Winform程序右下角弹窗消息提示
C#实现Winform程序右下角弹窗消息提示
150 0