0

0

修改图边权重

PHPz

PHPz

发布时间:2024-08-31 09:03:16

|

486人浏览过

|

来源于dev.to

转载

2699。修改图边权重

难度:

主题:图、堆(优先级队列)、最短路径

给你一个无向加权连通图,其中包含标记为0到n - 1的n个节点,以及一个整数数组edges,其中edges[i] = [ai, b i, wi] 表示节点 ai 和 bi 之间有一条边,权重为 wi.

某些边的权重为 -1 (wi = -1),而其他边的权重为 (wi > 0)。

你的任务是修改所有边的权重为-1,方法是在[1, 2 * 109范围内分配正整数值 ] 使得节点源和目的地之间的最短距离变得等于整数目标。如果有多次修改使源和目的地之间的最短距离等于目标,则其中任何一个都将被视为正确。

如果可以使从源到目的地的最短距离等于目标,则返回以任意顺序包含所有边(甚至未修改的边)的数组,如果不可能,则返回空数组 .

注意:不允许修改初始为正权重的边的权重。

示例1:

修改图边权重

  • 输入: n = 5,边 = [[4,1,-1],[2,0,-1],[0,3,-1],[4,3,-1] ],源 = 0,目的地 = 1,目标 = 5
  • 输出: [[4,1,1],[2,0,1],[0,3,3],[4,3,1]]
  • 解释:上图显示了对边缘的可能修改,使得从 0 到 1 的距离等于 5。

示例2:

修改图边权重

  • 输入: n = 3,边 = [[0,1,-1],[0,2,5]],源 = 0,目的地 = 2,目标 = 6
  • 输出: []
  • 解释: 上图包含初始边。通过修改权重-1的边是不可能使从0到2的距离等于6的。因此,返回一个空数组。

示例 3:

修改图边权重

  • 输入: n = 4,边 = [[1,0,4],[1,2,3],[2,3,5],[0,3,-1]],源= 0,目的地 = 2,目标 = 6
  • 输出: [[1,0,4],[1,2,3],[2,3,5],[0,3,1]]
  • 解释:上图显示了修改后的图,其中从 0 到 2 的最短距离为 6。

约束:

Joker AIx
Joker AIx

一站式AI创意生产平台,覆盖图像、视频、音频、文案全品类创作

下载
  • 1 <=n <=100
  • 1 <= edges.length <= n * (n - 1) / 2
  • 边[i].length == 3
  • 0 <= ai, bi < n
  • wi = -1 或 1 <= wi <= 107
  • ai != bi
  • 0 <= 源,目标 < n
  • 来源!=目的地
  • 1 <= 目标 <= 109
  • 图是连通的,不存在自环或重复边

提示:

  1. 首先,检查是否确实可以使从源到目的地的最短路径等于目标。
  2. 如果在没有修改边的情况下从源到目的地的最短路径小于目标,则这是不可能的。
  3. 如果从源到目的地的最短路径(包括要修改的边并为其分配临时权重 1)大于目标,那么它也是不可能的。
  4. 假设我们可以找到一条可修改的边 (u, v),使得从源到 u 的最短路径长度 (dis1) 加上从 v 到目的地的最短路径长度 (dis2) 小于目标 (dis1) + dis2 < target),那么我们可以将其权重更改为“target - dis1 - dis2”。
  5. 对于所有其他仍具有权重“-1”的边,将权重更改为足够大的数字(目标、目标 + 1 或 200000000 等)。

解决方案:

我们可以将方法分解如下:

方法:

  1. 对现有权重进行初步检查:

    • 首先,我们仅使用权重为正的边计算从源到目的地的最短路径,忽略权重为 -1 的边。
    • 如果这个距离已经大于目标,那么就不可能修改-1边来达到目标​​,所以我们返回一个空数组。
  2. 临时分配权重 1:

    • 接下来,为所有权重为-1的边分配临时权重1,并重新计算最短路径。
    • 如果这个最短路径仍然大于目标,那么就不可能达到目标,所以我们返回一个空数组。
  3. 修改特定边权重:

    • 迭代权重为-1的边缘并识别可以调整以完全匹配目标距离的边缘。这是通过调整边缘的权重来完成的,这样往返于该边缘的路径的组合距离就可以得出准确的目标距离。
    • 对于任何剩余的 -1 边,分配足够大的权重(例如 2 * 10^9)以确保它们不会影响最短路径。
  4. 返回修改后的边:

    • 最后,返回修改后的边列表。

让我们用 php 实现这个解决方案:2699。修改图边权重

<?php
private $kMax = 2000000000;

 /**
  * @param $n
  * @param $edges
  * @param $source
  * @param $destination
  * @param $target
  * @return array|mixed
  */
 function modifiedGraphEdges($n, $edges, $source, $destination, $target) {
    ...
    ...
    ...
    /**
     * go to ./solution.php
     */
 }

 /**
  * @param $graph
  * @param $src
  * @param $dst
  * @return int|mixed
  */
 function dijkstra($graph, $src, $dst) {
    ...
    ...
    ...
    /**
     * go to ./solution.php
     */
 }


// Example usage:

// Example 1
$n = 5;
$edges = [[4,1,-1],[2,0,-1],[0,3,-1],[4,3,-1]];
$source = 0;
$destination = 1;
$target = 5;
print_r(modifyGraphEdgeWeights($n, $edges, $source, $destination, $target)); // Output: [[4,1,1],[2,0,1],[0,3,3],[4,3,1]]

// Example 2
$n = 3;
$edges = [[0,1,-1],[0,2,5]];
$source = 0;
$destination = 2;
$target = 6;
print_r(modifyGraphEdgeWeights($n, $edges, $source, $destination, $target)); // Output: []

// Example 3
$n = 4;
$edges = [[1,0,4],[1,2,3],[2,3,5],[0,3,-1]];
$source = 0;
$destination = 2;
$target = 6;
print_r(modifyGraphEdgeWeights($n, $edges, $source, $destination, $target));  // Output: [[1,0,4],[1,2,3],[2,3,5],[0,3,1]]
?>

解释:

  • dijkstra 函数计算从源到所有其他节点的最短路径。
  • 我们最初计算忽略 -1 条边的最短路径。
  • 如果没有-1边的路径小于目标,函数返回一个空数组,表明无法调整权重以满足目标。
  • 否则,我们暂时将所有 -1 边设置为 1,并检查最短路径是否超过目标。
  • 如果是,则再次无法到达目标,我们返回一个空数组。
  • 然后我们策略性地修改-1边的权重,以实现精确目标的最短路径。

这种方法可以有效地检查和调整边缘权重,确保尽可能满足目标距离。

联系链接

如果您发现本系列有帮助,请考虑在 github 上给存储库 一颗星,或在您最喜欢的社交网络上分享该帖子?。您的支持对我来说意义重大!

如果您想要更多类似的有用内容,请随时关注我:

  • 领英
  • github

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
堆和栈的区别
堆和栈的区别

堆和栈的区别:1、内存分配方式不同;2、大小不同;3、数据访问方式不同;4、数据的生命周期。本专题为大家提供堆和栈的区别的相关的文章、下载、课程内容,供大家免费下载体验。

443

2023.07.18

堆和栈区别
堆和栈区别

堆(Heap)和栈(Stack)是计算机中两种常见的内存分配机制。它们在内存管理的方式、分配方式以及使用场景上有很大的区别。本文将详细介绍堆和栈的特点、区别以及各自的使用场景。php中文网给大家带来了相关的教程以及文章欢迎大家前来学习阅读。

605

2023.08.10

length函数用法
length函数用法

length函数用于返回指定字符串的字符数或字节数。可以用于计算字符串的长度,以便在查询和处理字符串数据时进行操作和判断。 需要注意的是length函数计算的是字符串的字符数,而不是字节数。对于多字节字符集,一个字符可能由多个字节组成。因此,length函数在计算字符串长度时会将多字节字符作为一个字符来计算。更多关于length函数的用法,大家可以阅读本专题下面的文章。

954

2023.09.19

github中文官网入口 github中文版官网网页进入
github中文官网入口 github中文版官网网页进入

github中文官网入口https://docs.github.com/zh/get-started,GitHub 是一种基于云的平台,可在其中存储、共享并与他人一起编写代码。 通过将代码存储在GitHub 上的“存储库”中,你可以: “展示或共享”你的工作。 持续“跟踪和管理”对代码的更改。

4238

2026.01.21

TypeScript类型系统进阶与大型前端项目实践
TypeScript类型系统进阶与大型前端项目实践

本专题围绕 TypeScript 在大型前端项目中的应用展开,深入讲解类型系统设计与工程化开发方法。内容包括泛型与高级类型、类型推断机制、声明文件编写、模块化结构设计以及代码规范管理。通过真实项目案例分析,帮助开发者构建类型安全、结构清晰、易维护的前端工程体系,提高团队协作效率与代码质量。

1

2026.03.13

Python异步编程与Asyncio高并发应用实践
Python异步编程与Asyncio高并发应用实践

本专题围绕 Python 异步编程模型展开,深入讲解 Asyncio 框架的核心原理与应用实践。内容包括事件循环机制、协程任务调度、异步 IO 处理以及并发任务管理策略。通过构建高并发网络请求与异步数据处理案例,帮助开发者掌握 Python 在高并发场景中的高效开发方法,并提升系统资源利用率与整体运行性能。

41

2026.03.12

C# ASP.NET Core微服务架构与API网关实践
C# ASP.NET Core微服务架构与API网关实践

本专题围绕 C# 在现代后端架构中的微服务实践展开,系统讲解基于 ASP.NET Core 构建可扩展服务体系的核心方法。内容涵盖服务拆分策略、RESTful API 设计、服务间通信、API 网关统一入口管理以及服务治理机制。通过真实项目案例,帮助开发者掌握构建高可用微服务系统的关键技术,提高系统的可扩展性与维护效率。

171

2026.03.11

Go高并发任务调度与Goroutine池化实践
Go高并发任务调度与Goroutine池化实践

本专题围绕 Go 语言在高并发任务处理场景中的实践展开,系统讲解 Goroutine 调度模型、Channel 通信机制以及并发控制策略。内容包括任务队列设计、Goroutine 池化管理、资源限制控制以及并发任务的性能优化方法。通过实际案例演示,帮助开发者构建稳定高效的 Go 并发任务处理系统,提高系统在高负载环境下的处理能力与稳定性。

50

2026.03.10

Kotlin Android模块化架构与组件化开发实践
Kotlin Android模块化架构与组件化开发实践

本专题围绕 Kotlin 在 Android 应用开发中的架构实践展开,重点讲解模块化设计与组件化开发的实现思路。内容包括项目模块拆分策略、公共组件封装、依赖管理优化、路由通信机制以及大型项目的工程化管理方法。通过真实项目案例分析,帮助开发者构建结构清晰、易扩展且维护成本低的 Android 应用架构体系,提升团队协作效率与项目迭代速度。

90

2026.03.09

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Git 教程
Git 教程

共21课时 | 4.2万人学习

Git版本控制工具
Git版本控制工具

共8课时 | 1.6万人学习

Git中文开发手册
Git中文开发手册

共0课时 | 94人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号