挖地雷——线性dp
P2196 [NOIP1996 提高组] 挖地雷 - 洛谷 | 计算机科学教育新生态 (luogu.com.cn)
刚开始想的是记忆化搜索,但是发现这个问题是一维的,用记忆化搜索会麻烦,所以用线性dp。
状态表示:走到第i个地窖后的地雷最大总数量。(以终点作为状态表示,遍历前i-1个)
状态计算: f [ i ] = m a x ( f [ 1 ] , f [2 ] , .. . ,f [ i - 1 ] ) +a [ i ] 与 f[ i ] 本身求最大值
新知识:如何正向输出路径:用递归。
注意不是return shuchu(pre[x])
void shuchu(int x) { if(pre[x]) shuchu(pre[x]); printf("%d ",x); }

1 #include <bits/stdc++.h> 2 using namespace std; 3 const int N=25; 4 int f[N],a[N],pre[N]; 5 bool st[N][N]; 6 int n; 7 8 void shuchu(int x) 9 { 10 if(pre[x]) shuchu(pre[x]); 11 printf("%d ",x); 12 } 13 14 int main() 15 { 16 scanf("%d",&n); 17 for(int i=1;i<=n;i++) 18 { 19 scanf("%d",&a[i]); 20 f[i]=a[i]; 21 } 22 for(int i=1;i<=n-1;i++) 23 for(int j=i+1;j<=n;j++) 24 scanf("%d",&st[i][j]); 25 26 int ans=0,pos=0; 27 for(int i=2;i<=n;i++) 28 { 29 for(int j=1;j<=i-1;j++) 30 { 31 if(st[j][i]&&f[i]<f[j]+a[i]) 32 { 33 f[i]=f[j]+a[i]; 34 pre[i]=j; 35 } 36 } 37 if(ans<f[i]) 38 { 39 ans=f[i]; 40 pos=i; 41 } 42 } 43 44 shuchu(pos); 45 printf("\n%d\n",ans); 46 return 0; 47 }
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· 单线程的Redis速度为什么快?
· SQL Server 2025 AI相关能力初探
· AI编程工具终极对决:字节Trae VS Cursor,谁才是开发者新宠?
· 展开说说关于C#中ORM框架的用法!