当前位置:网站首页>数字三角形模型 AcWing 1018. 最低通行费
数字三角形模型 AcWing 1018. 最低通行费
2022-07-06 12:15:00 【T_Y_F666】
数字三角形模型 AcWing 1018. 最低通行费
原题链接
算法标签
DP 线性DP
思路
由题意,花费时间应小于(2N−1) , 故不能走回头路, 类似于摘花生问题。
代码
#include<bits/stdc++.h>
#define int long long
#define rep(i, a, b) for(int i=a;i<b;++i)
#define Rep(i, a, b) for(int i=a;i>=b;--i)
using namespace std;
const int N = 105, INF = 0x3f3f3f3f;
int f[N][N], a[N][N];
inline int read(){
int s=0,w=1;
char ch=getchar();
while(ch<'0'||ch>'9'){if(ch=='-')w=-1;ch=getchar();}
while(ch>='0'&&ch<='9') s=s*10+ch-'0',ch=getchar();
return s*w;
}
void put(int x) {
if(x<0) putchar('-'),x=-x;
if(x>=10) put(x/10);
putchar(x%10^48);
}
signed main(){
ios::sync_with_stdio(false);
cin.tie(0);
cout.tie(0);
int n=read();
rep(i, 1, n+1){
rep(j, 1, n+1){
a[i][j]=read();
}
}
rep(i, 1, n+1){
rep(j, 1, n+1){
if(i==1&&j==1){
f[i][j]=a[i][j];
}else{
f[i][j]=INF;
if(i>1){
f[i][j]=min(f[i][j], f[i-1][j]+a[i][j]);
}
if(j>1){
f[i][j]=min(f[i][j], f[i][j-1]+a[i][j]);
}
}
}
}
printf("%lld", f[n][n]);
return 0;
}
原创不易
转载请标明出处
如果对你有所帮助 别忘啦点赞支持哈
边栏推荐
猜你喜欢
随机推荐
350. Intersection of two arrays II
AsyncHandler
golang的超时处理使用技巧
范式的数据库具体解释
Configuration and simple usage of the EXE backdoor generation tool quasar
5. 无线体内纳米网:十大“可行吗?”问题
Tencent cloud database public cloud market ranks top 2!
Crawler (14) - scrape redis distributed crawler (1) | detailed explanation
某东短信登录复活 安装部署教程
【云小课】EI第47课 MRS离线数据分析-通过Flink作业处理OBS数据
[play with Linux] [docker] MySQL installation and configuration
Analysis of rainwater connection
信息系统项目管理师---第八章 项目质量管理
Hudi vs Delta vs Iceberg
HDU 1026 search pruning problem within the labyrinth of Ignatius and the prince I
Alibaba data source Druid visual monitoring configuration
理解 YOLOV1 第二篇 预测阶段 非极大值抑制(NMS)
BUUCTF---Reverse---easyre
Synchronization of data create trigger synchronization table for each site
腾讯T4架构师,android面试基础







