P2858 [USACO06FEB] Treats for the Cows G/S 题解

P2858

题意

给一个数组。每天把最左或者最右的东西卖掉,第 i i i个东西,第 d a y day day天卖出的价格是 a [ i ] ∗ d a y a[i]*day a[i]∗day。

记忆化搜索

cpp 复制代码
void dfs(int l,int r,int day,ll sum)
{
	if(v[l][r]>=sum)return;
	v[l][r]=sum;
	if(l>r)//这就是dp答案
	{
		ans=max(ans,sum);
		return;
	}
	if(l<=n)dfs(l+1,r,day+1,sum+a[l]*day);
	if(r>=1)dfs(l,r-1,day+1,sum+a[r]*day);
}

TLE 63

正解dp

通过写dfs,我们可以发现对于状态dp[i][j]他的下一个状态就是dp[i+1][j]dp[i][j-1]。那么我们可以从当前状态出发计算下一个状态的值。我们可以用 d p [ i ] [ j ] dp[i][j] dp[i][j]表示从 [ i , j ] [i,j] [i,j]这个状态为起点的最大值。根据搜索的代码,答案就是 d p [ i ] [ i − 1 ] dp[i][i-1] dp[i][i−1]。记得long long

代码

cpp 复制代码
#include<bits/stdc++.h>
#include<cstring>
#include<queue>
#include<set>
#include<stack>
#include<vector>
#include<map>
#define ll long long
#define lhs printf("\n");
using namespace std;
const int N=1e5+10;
const int M=2024;
const int inf=0x3f3f3f3f;
ll a[N],n,dp[M][M],ans; //记得ll
int v[M][M];
void dfs(int l,int r,int day,ll sum)//记忆化
{
	if(v[l][r]>=sum)return;
	v[l][r]=sum;
	if(l>r)
	{
		ans=max(ans,sum);
		return;
	}
	if(l<=n)dfs(l+1,r,day+1,sum+a[l]*day);
	if(r>=1)dfs(l,r-1,day+1,sum+a[r]*day);
}
int main()
{
	scanf("%lld",&n); 
	for(int i=1;i<=n;i++)scanf("%lld",&a[i]);	
	for(int i=1;i<=n;i++)
	{
		for(int j=n;j>=i;j--)
		{
			int day=i-1+n-j+1;
			dp[i+1][j]=max(dp[i+1][j],dp[i][j]+a[i]*day);
			dp[i][j-1]=max(dp[i][j-1],dp[i][j]+a[j]*day);	
		}
	}
	for(int i=1;i<=n;i++)
	{
		ans=max(ans,dp[i][i-1]);
	}
	printf("%lld",ans);
	return 0;
}

AC记录

相关推荐
李泽辉_14 分钟前
深度学习算法学习(一):梯度下降法和最简单的深度学习核心原理代码
深度学习·学习·算法
꧁Q༒ོγ꧂17 分钟前
算法详解---大纲
算法
m0_6038887123 分钟前
Scaling Trends for Multi-Hop Contextual Reasoning in Mid-Scale Language Models
人工智能·算法·ai·语言模型·论文速览
Xの哲學26 分钟前
Linux io_uring 深度剖析: 重新定义高性能I/O的架构革命
linux·服务器·网络·算法·边缘计算
comli_cn33 分钟前
残差链接(Residual Connection)
人工智能·算法
Aaron158840 分钟前
基于VU13P在人工智能高速接口传输上的应用浅析
人工智能·算法·fpga开发·硬件架构·信息与通信·信号处理·基带工程
予枫的编程笔记42 分钟前
【论文解读】DLF:以语言为核心的多模态情感分析新范式 (AAAI 2025)
人工智能·python·算法·机器学习
im_AMBER1 小时前
Leetcode 99 删除排序链表中的重复元素 | 合并两个链表
数据结构·笔记·学习·算法·leetcode·链表
王老师青少年编程1 小时前
信奥赛C++提高组csp-s之欧拉回路
c++·算法·csp·欧拉回路·信奥赛·csp-s·提高组
墨有6661 小时前
数学分析栈的出栈顺序:从算法判断到数学本质(卡特兰数初探)
c++·算法·数学建模