当前位置:网站首页>LeetCode每日一题(1514. Path with Maximum Probability)
LeetCode每日一题(1514. Path with Maximum Probability)
2022-07-23 17:16:00 【wangjun861205】
You are given an undirected weighted graph of n nodes (0-indexed), represented by an edge list where edges[i] = [a, b] is an undirected edge connecting the nodes a and b with a probability of success of traversing that edge succProb[i].
Given two nodes start and end, find the path with the maximum probability of success to go from start to end and return its success probability.
If there is no path from start to end, return 0. Your answer will be accepted if it differs from the correct answer by at most 1e-5.
Example 1:

Input: n = 3, edges = [[0,1],[1,2],[0,2]], succProb = [0.5,0.5,0.2], start = 0, end = 2
Output: 0.25000
Explanation: There are two paths from start to end, one having a probability of success = 0.2 and the other has 0.5 * 0.5 = 0.25.
Example 2:

Input: n = 3, edges = [[0,1],[1,2],[0,2]], succProb = [0.5,0.5,0.3], start = 0, end = 2
Output: 0.30000
Example 3:

Input: n = 3, edges = [[0,1]], succProb = [0.5], start = 0, end = 2
Output: 0.00000
Explanation: There is no path between 0 and 2.
Constraints:
- 2 <= n <= 10^4
- 0 <= start, end < n
- start != end
- 0 <= a, b < n
- a != b
- 0 <= succProb.length == edges.length <= 2*10^4
- 0 <= succProb[i] <= 1
- There is at most one edge between every two nodes.
与计算最短路径的方法相同, 只不过把最短路径换成了最大概率, 广度优先更新每个节点的最大概率, 直到最后没有节点可更新为止
use std::collections::HashMap;
impl Solution {
pub fn max_probability(
n: i32,
edges: Vec<Vec<i32>>,
succ_prob: Vec<f64>,
start: i32,
end: i32,
) -> f64 {
let mut probs = vec![0f64; n as usize];
let edges: HashMap<i32, Vec<(i32, f64)>> =
edges
.into_iter()
.zip(succ_prob)
.fold(HashMap::new(), |mut m, (l, p)| {
m.entry(l[0]).or_insert(Vec::new()).push((l[1], p));
m.entry(l[1]).or_insert(Vec::new()).push((l[0], p));
m
});
probs[start as usize] = 1f64;
loop {
let mut modified = false;
for i in 0..n {
if probs[i as usize] > 0f64 {
let cp = probs[i as usize];
if let Some(nexts) = edges.get(&i) {
for &(n, p) in nexts {
let np = cp * p;
if np > probs[n as usize] {
probs[n as usize] = np;
modified = true;
}
}
}
}
}
if !modified {
break;
}
}
probs[end as usize]
}
}
边栏推荐
猜你喜欢

AE tutorial, how to animate illustrator layered documents in after effects?

Building virtual private network based on softther

作为一名后台开发人员,你必须知道的两种过滤器

MEE | 浙大程磊组开发设计与构建合成菌群新方法
[paper reading] gettext: trajectory flow map enhanced transformer for next POI recommendation

Source code analysis of ThreadPoolExecutor

Weights & Biases (一)
![Multithreading [comprehensive study of graphics and text]](/img/70/8a1227b2159349cf25a85dff8f9d1c.png)
Multithreading [comprehensive study of graphics and text]

Storage structure and method of graph (II)

多线程&高并发(全网最新:面试题+导图+笔记)面试手稳心不慌
随机推荐
Read data from txt and convert it to Yolo format data
Learn and understand Architecture Design from business development
Integer and = = compare
【机器学习】吴恩达:终生学习
The first layer of OSI model: physical layer, the cornerstone of existence!
日志框架【详解学习】
【C语言】程序环境和预处理
[paper reading] gettext: trajectory flow map enhanced transformer for next POI recommendation
FPGA implementation of IIC bus of IIC protocol (II) (single read / write drive)
迷宫类dp整合
Paddlenlp's UIE classification model [taking emotional propensity analysis news classification as an example] including intelligent annotation scheme)
Terminal command (all)
Leetcode sword finger offer II 115. reconstruction sequence: diagram topology sorting
Redis [super superfine introductory tutorial]
Ros2 self study notes: rviz visualization tool
Opencv (13): brief introduction to cv2.findcontours, cv:: findcontours and description of cv2.findcontours function in various versions of opencv
Google正在改进所有产品中的肤色表现 践行“图像公平”理念
Handwriting bind, call, apply is actually very simple
1、 Reptile concept and basic process
UPC 2022 summer personal training game 12 (number of combinations b)