博客
关于我
G. Reducing Delivery Cost(思维+最短路)
阅读量:242 次
发布时间:2019-03-01

本文共 2202 字,大约阅读时间需要 7 分钟。

如何优化处理免费边对最短路径的影响

在处理图中存在免费边的情况下,找到所有点对的最短路径是一个具有挑战性的任务。传统的方法可能需要对每条边进行暴力枚举,然后针对每个点进行Dijkstra算法,这种方法的时间复杂度通常较高。以下是一种优化的方法,能够有效地处理这种情况,同时减少计算量。

方法概述

我们提出了一种基于预处理的方法,通过分析每条边对各个点对的最短路径的影响,来找到最优解。具体步骤如下:

  • 预处理每个点的最短路径:对于图中的每个点,使用Dijkstra算法计算其到所有其他点的最短路径。这样可以得到一个全面的距离矩阵。

  • 分析每条边的影响:对于每条边(a, b),我们需要分析其对不同点对的最短路径的影响。具体分为以下三种情况:

    • 情况1:边(a, b)不在任何点对的最短路径上,添加后仍然不在任何最短路径上。
    • 情况2:边(a, b)不在原来的最短路径上,但添加后可能进入另一个最短路径。
    • 情况3:边(a, b)原本就在某些点对的最短路径上,添加后可能改变这些点对的最短路径。
  • 计算最小值:对于每条边,计算其对所有点对的最短路径的影响,然后取最小值作为最终结果。

  • 这种方法的时间复杂度为O(mk + n² log m),其中m是边的数量,n是点的数量,k是需要处理的点对数量。这比传统的暴力枚举方法更高效。

    具体实现步骤

  • 预处理最短路径:使用Dijkstra算法对图中的每个点进行一次计算,得到一个距离矩阵f[i][j],表示点i到点j的最短路径距离。

  • 遍历每条边:对于每条边(a, b),考虑其对点对的最短路径的影响。具体来说,对于每条边,计算其对所有点对的最短路径的影响,然后更新最终的最短路径距离。

  • 更新最终结果:对于每条边,计算其对所有点对的最短路径的影响,然后取最小值作为最终结果。

  • 代码示例

    #include 
    #include
    #include
    #include
    #include
    #include
    #include
    #include
    #include
    #define debug(a) cout << a << endl;using namespace std;const int maxn = 1e3 + 100;typedef long ll;typedef pair
    P;LL n, m, k, start;struct edge { LL to, cost;};vector
    g[maxn];vector
    > Edge;void dijkstra() { LL s = start; memset(dis, 0x3f, sizeof(dis)); memset(vis, 0, sizeof(vis)); dis[s] = 0; priority_queue
    , greater

    > que; que.push({0, s}); while (!que.empty()) { P p = que.top(); que.pop(); LL v = p.second; if (vis[v]) continue; vis[v] = 1; for (LL i = 0; i < g[v].size(); i++) { edge e = g[v][i]; if (dis[e.to] > dis[v] + e.cost) { dis[e.to] = dis[v] + e.cost; que.push({dis[e.to], e.to}); } } } for (LL j = 1; j <= n; j++) { f[s][j] = dis[j]; }}int main() { cin.tie(0); std::ios::sync_with_stdio(false); cin >> n >> m >> k; vector

    > v; for (LL i = 1; i <= k; i++) { LL a, b; cin >> a >> b; v.push_back({a, b}); } for (LL i = 1; i <= n; i++) { start = i; dijkstra(); } LL sum = 1e18; for (auto i : Edge) { LL a = i.first, b = i.second; LL ans = 0; for (auto j : v) { LL u = j.first, w = j.second; LL option1 = f[u][u] + f[u][a] + f[w][b]; LL option2 = f[u][u] + f[u][b] + f[w][a]; ans += min(f[u][w], option1, option2); } sum = min(sum, ans); } cout << sum << endl;}

    总结

    通过预处理每个点的最短路径,并分析每条边对点对的最短路径的影响,我们可以有效地找到图中所有点对的最短路径,即使存在大量免费边的情况。这种方法的时间复杂度优于传统的暴力枚举方法,使得处理大规模图问题更加高效。

    转载地址:http://twct.baihongyu.com/

    你可能感兴趣的文章
    NoClassDefFoundError: org/springframework/boot/context/properties/ConfigurationBeanFactoryMetadata
    查看>>
    node exporter完整版
    查看>>
    Node JS: < 一> 初识Node JS
    查看>>
    Node Sass does not yet support your current environment: Windows 64-bit with Unsupported runtime(72)
    查看>>
    Node 裁切图片的方法
    查看>>
    Node+Express连接mysql实现增删改查
    查看>>
    node, nvm, npm,pnpm,以前简单的前端环境为什么越来越复杂
    查看>>
    Node-RED中Button按钮组件和TextInput文字输入组件的使用
    查看>>
    Node-RED中Switch开关和Dropdown选择组件的使用
    查看>>
    Node-RED中使用html节点爬取HTML网页资料之爬取Node-RED的最新版本
    查看>>
    Node-RED中使用JSON数据建立web网站
    查看>>
    Node-RED中使用json节点解析JSON数据
    查看>>
    Node-RED中使用node-random节点来实现随机数在折线图中显示
    查看>>
    Node-RED中使用node-red-browser-utils节点实现选择Windows操作系统中的文件并实现图片预览
    查看>>
    Node-RED中使用node-red-contrib-image-output节点实现图片预览
    查看>>
    Node-RED中使用node-red-node-ui-iframe节点实现内嵌iframe访问其他网站的效果
    查看>>
    Node-RED中使用Notification元件显示警告讯息框(温度过高提示)
    查看>>
    Node-RED中使用range范围节点实现从一个范围对应至另一个范围
    查看>>
    Node-RED中实现HTML表单提交和获取提交的内容
    查看>>
    Node-RED中将CSV数据写入txt文件并从文件中读取解析数据
    查看>>