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记录

相关推荐
SweetCode5 分钟前
裴蜀定理:整数解的奥秘
数据结构·python·线性代数·算法·机器学习
ゞ 正在缓冲99%…19 分钟前
leetcode76.最小覆盖子串
java·算法·leetcode·字符串·双指针·滑动窗口
xuanjiong19 分钟前
纯个人整理,蓝桥杯使用的算法模板day2(0-1背包问题),手打个人理解注释,超全面,且均已验证成功(附带详细手写“模拟流程图”,全网首个
算法·蓝桥杯·动态规划
惊鸿.Jh38 分钟前
【滑动窗口】3254. 长度为 K 的子数组的能量值 I
数据结构·算法·leetcode
明灯L39 分钟前
《函数基础与内存机制深度剖析:从 return 语句到各类经典编程题详解》
经验分享·python·算法·链表·经典例题
碳基学AI1 小时前
哈尔滨工业大学DeepSeek公开课:探索大模型原理、技术与应用从GPT到DeepSeek|附视频与讲义免费下载方法
大数据·人工智能·python·gpt·算法·语言模型·集成学习
补三补四1 小时前
机器学习-聚类分析算法
人工智能·深度学习·算法·机器学习
独好紫罗兰1 小时前
洛谷题单3-P5718 【深基4.例2】找最小值-python-流程图重构
开发语言·python·算法
正脉科工 CAE仿真1 小时前
基于ANSYS 概率设计和APDL编程的结构可靠性设计分析
人工智能·python·算法
Dovis(誓平步青云)2 小时前
【数据结构】排序算法(中篇)·处理大数据的精妙
c语言·数据结构·算法·排序算法·学习方法