news 2026/5/30 7:04:02

【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/5/28 4:01:51

Agent间信任机制设计,破解跨领域协作中的安全与一致性难题

第一章&#xff1a;Agent间信任机制设计&#xff0c;破解跨领域协作中的安全与一致性难题 在分布式智能系统中&#xff0c;多个自治Agent需在无中心化控制的前提下实现高效协作。然而&#xff0c;跨领域场景下信息不对称、行为不可预测等问题加剧了安全风险与状态不一致的挑战。…

作者头像 李华
网站建设 2026/5/27 1:07:24

图形显示验证错误:新手必读指南

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容&#xff1a; 开发一个新手友好的教程应用&#xff0c;包含&#xff1a;1. 图形显示系统基础概念图解 2. 常见错误原因卡通式说明 3. 三步解决法教学 4. 互动式练习环节。要求使用简单的HTML/CSS…

作者头像 李华
网站建设 2026/5/29 8:31:27

1小时打造编辑分配系统原型:快马平台实战

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容&#xff1a; 在快马平台上快速创建一个编辑分配系统原型&#xff0c;要求&#xff1a;1) 使用自然语言描述系统需求即可生成基础代码&#xff1b;2) 包含编辑管理、任务管理和简单分配功能&…

作者头像 李华
网站建设 2026/5/29 20:55:07

比传统调试快10倍:自动化解决Chrome请求错误

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容&#xff1a; 开发一个Chrome请求异常自动化处理工具&#xff0c;功能包括&#xff1a;1. 一键式错误捕获和分析&#xff1b;2. 自动测试常见解决方案&#xff08;如清除缓存、禁用扩展等&#x…

作者头像 李华
网站建设 2026/5/23 21:55:58

【高可用系统必备技能】:精准调整环境Agent监测频率,提升响应速度40%

第一章&#xff1a;环境 Agent 的监测频率 在分布式系统与云原生架构中&#xff0c;环境 Agent 扮演着关键角色&#xff0c;负责采集主机资源使用情况、服务运行状态及安全事件等数据。监测频率的设定直接影响系统性能开销与监控实时性之间的平衡。过高频率可能导致资源争用&am…

作者头像 李华