jzoj6313-Maja【dp】

正题


题目大意

n ∗ m n*m nm的格子,从 ( A , B ) (A,B) (A,B)出发,走 K K K步,然后要求回到 ( A , B ) (A,B) (A,B),求路径最大价值(可以重复经过一个点,但不能停留)。


解题思路

我们可以将回路转换为一条 K 2 \frac{K}{2} 2K的路径,然后原路返回。

然后我们发现这条路径一定会在某个位置循环地走,然后显然有循环节大小为2(不懂的评论说)。

f k , i , j f_{k,i,j} fk,i,j表示已经走了 k k k步,然后在 ( i , j ) (i,j) (i,j)这个点时的最大价值。

然后对于每个 f k , i , j f_{k,i,j} fk,i,j有贡献 ( f k , i , j + w i , j ) ∗ ( K − k ) 2 − a i , j (f_{k,i,j}+w_{i,j})*\frac{(K-k)}{2}-a_{i,j} (fk,i,j+wi,j)2(Kk)ai,j


c o d e code code

#include<cstdio>
#include<cstring>
#include<algorithm>
#include<queue>
#define ll long long
using namespace std;
const ll N=110,dx[4]={1,-1,0,0},dy[4]={0,0,1,-1};
ll n,m,A,B,k,f[2][N][N],dep[N][N],dis[N][N],a[N][N],ans,K,w[N][N];
int main()
{
	freopen("maja.in","r",stdin);
	freopen("maja.out","w",stdout);
	scanf("%lld%lld%lld%lld%lld",&n,&m,&A,&B,&K);
	for(ll i=1;i<=n;i++)
		for(ll j=1;j<=m;j++)
			scanf("%lld",&a[i][j]);
	memset(f,-127,sizeof(f));
	f[0][A][B]=0;K/=2;
	for(ll k=1;k<=min(n*m,K);k++){
		memset(f[k&1],-127,sizeof(f[k&1]));
		for(ll i=1;i<=n;i++)
			for(ll j=1;j<=m;j++){
				if(k==1){
					for(ll q=0;q<4;q++)
						w[i][j]=max(w[i][j],a[i+dx[q]][j+dy[q]]);
					w[i][j]+=a[i][j];
				}
				for(ll q=0;q<4;q++)
					f[k&1][i][j]=max(f[k&1][i][j],f[~k&1][i+dx[q]][j+dy[q]]+a[i][j]);
					if(f[k&1][i][j]<0) continue;
					ans=max(ans,(f[k&1][i][j]+(K-k)/2*w[i][j])*2-a[i][j]);
			}
	}
	printf("%lld",ans);
} 
基于bert实现关系三元组抽取python源码+数据集+项目说明.zip基于bert实现关系三元组抽取python源码+数据集+项目说明.zip基于bert实现关系三元组抽取python源码+数据集+项目说明.zip基于bert实现关系三元组抽取python源码+数据集+项目说明.zip基于bert实现关系三元组抽取python源码+数据集+项目说明.zip 个人大四的毕业设计、课程设计、作业、经导师指导并认可通过的高分设计项目,评审平均分达96.5分。主要针对计算机相关专业的正在做毕设的学生和需要项目实战练习的学习者,也可作为课程设计、期末大作业。 [资源说明] 不懂运行,下载完可以私聊问,可远程教学 该资源内项目源码是个人的毕设或者课设、作业,代码都测试ok,都是运行成功后才上传资源,答辩评审平均分达到96.5分,放心下载使用! 1、该资源内项目代码都经过测试运行成功,功能ok的情况下才上传的,请放心下载使用! 2、本项目适合计算机相关专业(如计科、人工智能、通信工程、自动化、电子信息等)的在校学生、老师或者企业员工下载学习,也适合小白学习进阶,当然也可作为毕设项目、课程设计、作业、项目初期立项演示等。 3、如果基础还行,也可在此代码基础上进行修改,以实现其他功能,也可用于毕设、课设、作业等。 下载后请首先打开README.md文件(如有),供学习参考。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值