博客
关于我
51nod 1084 矩阵取数问题 V2
阅读量:631 次
发布时间:2019-03-14

本文共 1193 字,大约阅读时间需要 3 分钟。

51nod 1084 矩阵取数问题 V2

递归式:

if x1 != x2 | dp[step + 1][x1][x2] = max{dp[step][x1’][x2’]} + a[x1][y1] + a[x2][y2]
if x1 == x2 | dp[step + 1][x1][x2] = max{dp[step][x1’][x2’]} + a[x1][y1]。
使用step减少空间使用
如图:
这里写图片描述
初始值:
dp[0][x][y] = 0;

#include 
#include
#include
#include
#include
#include
#include
using namespace std;#define LL long long#define INF 0x3f3f3f3f#define PI acos(-1.0)#define E 2.71828#define MOD 1000000007#define N 210#define M 5010int n,m;int p[N][N];int dp[N*2][N][N];int main(){ scanf("%d%d",&m,&n); for(int i = 1; i <= n; i++) for(int j = 1; j <= m; j++) scanf("%d",&p[i][j]); memset(dp,0,sizeof(dp)); for(int k = 1; k < n+m; k++) { for(int i = 1; i<=n && i<=k; i++) { for(int j = 1; j<=n && j<=k; j++) { dp[k][i][j]=max(dp[k][i][j],dp[k-1][i-1][j-1]+p[i][k-i+1]+(i==j?0:p[j][k-j+1])); dp[k][i][j]=max(dp[k][i][j],dp[k-1][i-1][j]+p[i][k-i+1]+(i==j?0:p[j][k-j+1])); dp[k][i][j]=max(dp[k][i][j],dp[k-1][i][j-1]+p[i][k-i+1]+(i==j?0:p[j][k-j+1])); dp[k][i][j]=max(dp[k][i][j],dp[k-1][i][j]+p[i][k-i+1]+(i==j?0:p[j][k-j+1])); //printf("dp[%d][%d][%d] = %d\n",k,i,j,dp[k][i][j]); } } } printf("%d\n",dp[n+m-1][n][n]); return 0;}
你可能感兴趣的文章
MySQL查询语句:揭秘专家秘籍,让你秒变数据库达人!
查看>>
mysql查询超时对PHP执行的影响
查看>>
mysql查询输出到excel文件_如何保存mysql查询输出到excel或.txt文件?
查看>>
mysql查询过程
查看>>
MySQL模拟Oracle序列sequence
查看>>
Mysql模糊查询like效率,以及更高效的写法
查看>>
MySQL死锁套路:一次诡异的批量插入死锁问题分析
查看>>
Mysql死锁问题Deadlock found when trying to get lock;try restarting transaction
查看>>
mysql每个数据库的最大连接数_MySQL数据库最大连接数
查看>>
Mysql流程控制结构,if函数、case结构、if结构、循环结构
查看>>
mysql添加外网访问权限
查看>>
mysql添加用户
查看>>
MySQL添加用户、删除用户与授权
查看>>
mysql添加用户及权限
查看>>
Mysql添加用户并授予只能查询权限
查看>>
mysql添加用户权限报1064 - You have an error in your SQL syntax问题解决
查看>>
mysql添加索引
查看>>
mysql添加表注释、字段注释、查看与修改注释
查看>>
mysql清理undo线程_MySQL后台线程的清理工作
查看>>
mysql清空带外键的表
查看>>