news 2026/6/23 19:49:12

【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/6/23 4:07:02

【康复效率提升300%的秘密】:深度解析医疗Agent自主调参机制

第一章&#xff1a;医疗康复Agent方案调整的演进与挑战随着人工智能在医疗领域的深度渗透&#xff0c;面向康复治疗的智能Agent系统正经历从规则驱动到数据驱动的范式转变。早期系统依赖预设临床路径和固定决策树&#xff0c;难以应对患者个体差异与动态恢复进程。现代康复Agen…

作者头像 李华
网站建设 2026/6/23 21:33:15

htop入门指南:5分钟掌握Linux系统监控

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容&#xff1a; 制作一个交互式htop学习应用&#xff1a;1.分章节介绍htop界面元素 2.内置模拟环境供新手练习 3.实时反馈操作正确性。要求采用终端ASCII动画教学&#xff0c;包含成就系统激励学习…

作者头像 李华
网站建设 2026/6/23 13:49:21

传统热部署VS快马AI:效率提升300%的对比实验

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容&#xff1a; 创建一个对比实验项目&#xff0c;要求&#xff1a;1. 左侧传统方式&#xff1a;手动配置Spring Boot DevTools的完整流程 2. 右侧AI方式&#xff1a;通过自然语言描述生成配置 3. …

作者头像 李华
网站建设 2026/6/23 18:41:41

用htop源码快速构建自定义监控工具

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容&#xff1a; 基于htop源码开发一个最小化监控原型&#xff1a;1.保留核心进程监控功能 2.添加自定义指标采集模块接口 3.支持插件式扩展。要求编译后的二进制小于原版htop的70%&#xff0c;使用…

作者头像 李华