news 2026/2/2 13:46:06

【Leetcode】1786. Number of Restricted Paths From First to Last Node

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
【Leetcode】1786. Number of Restricted Paths From First to Last Node

题目地址:

https://leetcode.com/problems/number-of-restricted-paths-from-first-to-last-node/description/

给定一个n nn个点m mm条边的无向非负权图,顶点编号为1 ∼ n 1\sim n1n,每个点到n nn可以求出最短距离,记为d [ u ] d[u]d[u];问从1 11n nn存在多少条满足d [ 1 ] > d [ i 1 ] > d [ i 2 ] > . . . > d [ n ] d[1]>d[i_1]>d[i_2]>...>d[n]d[1]>d[i1]>d[i2]>...>d[n]的路径。答案对1 0 9 + 7 10^9+7109+7取模。

为了求每个点到点n nn的最短路,可以用Dijkstra算法来做,以n nn为源点即可。接着,设f [ u ] f[u]f[u]是从u uu出发到n nn的满足条件的路径数,则有:f [ u ] = ∑ u → v ∧ d [ u ] > d [ v ] f [ v ] f[u]=\sum_{u\to v \land d[u]>d[v]} f[v]f[u]=uvd[u]>d[v]f[v]边界条件f [ n ] = 1 f[n]=1f[n]=1。可以用记忆化搜索来做。代码如下:

classSolution{public:usingPII=pair<int,int>;intcountRestrictedPaths(intn,vector<vector<int>>&es){staticconstexprintINF=2e9,MOD=1e9+7;intm=es.size();vector<int>h(n+1,-1),e(m<<1),ne(m<<1),w(m<<1);intidx=0;autoadd=[&](inta,intb,intc){e[idx]=b,ne[idx]=h[a],w[idx]=c,h[a]=idx++;};for(auto&e:es){inta=e[0],b=e[1],c=e[2];add(a,b,c);add(b,a,c);}vector<int>dist(n+1,INF);dist[n]=0;vector<bool>vis(n+1);priority_queue<PII,vector<PII>,greater<>>heap;heap.push({0,n});while(heap.size()){auto[d,u]=heap.top();heap.pop();if(vis[u])continue;vis[u]=true;for(inti=h[u];~i;i=ne[i]){intv=e[i];if(dist[v]>d+w[i]){dist[v]=d+w[i];heap.push({dist[v],v});}}}vector<int>f(n+1,-1);autodfs=[&](auto&&self,intu)->int{if(~f[u])returnf[u];if(u==n)returnf[u]=1;f[u]=0;for(inti=h[u];~i;i=ne[i]){intv=e[i];if(dist[v]<dist[u])f[u]=(f[u]+self(self,v))%MOD;}returnf[u];};returndfs(dfs,1);}};

时间复杂度O ( m log ⁡ n + m + n ) O(m\log n+m+n)O(mlogn+m+n),空间O ( m + n ) O(m+n)O(m+n)

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/1/31 2:32:22

基于Docker搭建kafka集群

在单台服务器上使用 Docker Compose 部署 Kafka 3.7 KRaft 集群&#xff08;3 节点&#xff09; 。所有 3 个 Kafka 节点&#xff08;combined mode&#xff1a;broker controller&#xff09;运行在同一台物理机上&#xff0c;通过不同端口区分&#xff0c;适用于开发、测试或…

作者头像 李华
网站建设 2026/1/26 4:05:14

电商网站商品图片选择器实战开发指南

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容&#xff1a; 开发一个电商后台的商品图片选择器&#xff0c;要求&#xff1a;1. 支持同时上传最多20张商品图片 2. 图片自动压缩至800px宽度 3. 生成不同尺寸缩略图 4. 实现图片排序功能 5. 支持…

作者头像 李华
网站建设 2026/2/1 10:47:49

揭秘云原生Agent崩溃真相:3步完成自动化故障恢复

第一章&#xff1a;揭秘云原生Agent崩溃真相&#xff1a;3步完成自动化故障恢复 在云原生环境中&#xff0c;Agent作为连接控制平面与工作负载的关键组件&#xff0c;频繁因资源争用、网络波动或配置异常导致崩溃。手动介入不仅响应滞后&#xff0c;还可能扩大故障影响面。实现…

作者头像 李华
网站建设 2026/1/19 19:13:23

新手必看:Makefile报错‘no rule to make target‘完全指南

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容&#xff1a; 开发一个面向新手的Makefile教学工具&#xff0c;要求&#xff1a;1. 解释Makefile基本概念&#xff1b;2. 用简单示例演示no rule to make target错误&#xff1b;3. 提供分步解决…

作者头像 李华
网站建设 2026/1/26 6:20:01

从数据采集到干预建议,一文讲透教育 Agent 的7步学情分析闭环

第一章&#xff1a;教育 Agent 学情分析的核心价值与演进路径在人工智能驱动教育变革的背景下&#xff0c;教育 Agent 作为智能化教学系统的核心组件&#xff0c;正逐步实现从“辅助工具”向“认知伙伴”的角色跃迁。其核心能力之一——学情分析&#xff0c;已成为精准教学与个…

作者头像 李华