洛谷 - P1434 - 滑雪 - 有向图最长链
https://www.luogu.org/problemnew/show/P1434
有向图的最长链怎么求?有环肯定不行,这里保证无环。(否则应该使用toposort先求出所有不带环的位置)
设dp[u]=以u点开始的最长链的长度,那么以u为子节点的v就有dp[v]=max(dp[v],dp[u]+1),遍历其每个子节点就可以得知其最长链。
所以最简单的方法其实是记忆化搜索。
第一次完全手写前向星版本的dfs。
#include<bits/stdc++.h> using namespace std; #define ll long long int g[105][105]; int head[10005]; struct Edge{ int v,nxt; Edge(int v=0,int nxt=0):v(v),nxt(nxt){} }edge[10005*4]; int indeg[10005]; int etop=0; void addedge(int u,int v){ edge[etop].v=v; edge[etop].nxt=head[u]; indeg[v]++; head[u]=etop++; } int n,m; int dp[10005]; int dfs(int id){ if(dp[id]!=-1) return dp[id]; else{ int res=0; for(int i=head[id];i!=-1;i=edge[i].nxt){ res=max(res,dfs(edge[i].v)); } res++; return dp[id]=res; } } int main(){ scanf("%d%d",&n,&m); memset(g,0x3f,sizeof(g)); memset(head,-1,sizeof(head)); memset(dp,-1,sizeof(dp)); for(int i=1;i<=n;i++){ for(int j=1;j<=m;j++){ scanf("%d",&g[i][j]); } } for(int i=1;i<=n;i++){ for(int j=1;j<=m;j++){ if(g[i][j]>g[i-1][j]){ addedge((i-1)*m+j,(i-2)*m+j); } if(g[i][j]>g[i+1][j]){ addedge((i-1)*m+j,(i)*m+j); } if(g[i][j]>g[i][j-1]){ addedge((i-1)*m+j,(i-1)*m+j-1); } if(g[i][j]>g[i][j+1]){ addedge((i-1)*m+j,(i-1)*m+j+1); } } } int ans=0; for(int i=1;i<=n;i++){ for(int j=1;j<=m;j++){ if(indeg[(i-1)*m+j]==0){ ans=max(ans,dfs((i-1)*m+j)); } } } printf("%d\n",ans); }
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】凌霞软件回馈社区,博客园 & 1Panel & Halo 联合会员上线
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 如何打造一个高并发系统?
· .NET Core GC压缩(compact_phase)底层原理浅谈
· 现代计算机视觉入门之:什么是图片特征编码
· .NET 9 new features-C#13新的锁类型和语义
· Linux系统下SQL Server数据库镜像配置全流程详解
· Sdcb Chats 技术博客:数据库 ID 选型的曲折之路 - 从 Guid 到自增 ID,再到
· 语音处理 开源项目 EchoSharp
· 《HelloGitHub》第 106 期
· Huawei LiteOS基于Cortex-M4 GD32F4平台移植
· mysql8.0无备份通过idb文件恢复数据过程、idb文件修复和tablespace id不一致处