caioj 1079 动态规划入门(非常规DP3:钓鱼)(动规中的坑)「建议收藏」

caioj 1079 动态规划入门(非常规DP3:钓鱼)(动规中的坑)「建议收藏」caioj 1079 动态规划入门(非常规DP3:钓鱼)(动规中的坑)

大家好,又见面了,我是你们的朋友全栈君。

这道题写了我好久, 交上去90分,就是死活AC不了

后来发现我写的程序有根本性的错误,90分只是数据弱

#include<cstdio>
#include<algorithm>
#define REP(i, a, b) for(int i = (a); i < (b); i++)
using namespace std;

const int MAXN = 2123;
int dp[MAXN][MAXN], t[MAXN]; 
int f[MAXN], d[MAXN], h, n;

int main()
{
	scanf("%d%d", &n, &h);
	h *= 12;
	REP(i, 1, n + 1) scanf("%d", &f[i]);
	REP(i, 1, n + 1) scanf("%d", &d[i]);
	REP(i, 1, n) scanf("%d", &t[i]);
	
	REP(i, 0, h + 1) dp[0][i] = 0;
	REP(i, 0, n + 1) dp[i][0] = 0;
	REP(i, 1, n + 1)
	{
		int fish = f[i];
		REP(j, 1, h + 1)
		{
			if(j-t[i-1] > 0 && dp[i-1][j-t[i-1]] > dp[i][j-1] + fish)
				dp[i][j] = dp[i-1][j-t[i-1]], fish = f[i];
			else
				dp[i][j] = dp[i][j-1] + fish, fish = max(fish - d[i], 0);	
		}
	}
	printf("%d\n", dp[n][h]);
	
	return 0;
}

我一开始的程序是这样的,但是又非常多的问题

(1)我这个程序是以最后一个池塘为i定义的,所以应该是max(dp[i][h]),答案不一定是dp[n][h]

(2)dp[i][0] = 0有点问题,因为这个时候不是为0的,只有1是起点。这个时候就相当于每个点都可以是
起点了。应该是dp[0][0] = 0,其他未负无穷。有意义的设为0,其他为负无穷。

 

正解应该是枚举当前这个池塘钓的时间和上个池塘钓的时间,取最优。

#include<cstdio>
#include<algorithm>
#include<cstring>
#define REP(i, a, b) for(int i = (a); i < (b); i++)
using namespace std;

const int MAXN = 212;
int dp[MAXN][MAXN * 10], t[MAXN]; 
int diao[MAXN][MAXN], f[MAXN], d[MAXN], h, n;

int main()
{
	scanf("%d%d", &n, &h);
	h *= 12;
	REP(i, 1, n + 1) scanf("%d", &f[i]);
	REP(i, 1, n + 1) scanf("%d", &d[i]);
	REP(i, 1, n) scanf("%d", &t[i]);
	
	REP(i, 1, n + 1)
	{
		diao[i][0] = 0;
		int fish = f[i];
		REP(j, 1, h + 1)
		{
			diao[i][j] = diao[i][j-1] + fish;
			fish = max(fish - d[i], 0);
		}
	}
	
	memset(dp, -63, sizeof(dp));
	int ans = 0;
	REP(i, 0, h + 1) dp[0][i] = 0;
	REP(i, 1, n + 1)
		REP(j, t[i-1], h + 1)
			REP(k, 0, j - t[i-1] + 1)
			{
				dp[i][j] = max(dp[i][j], dp[i-1][k] + diao[i][j-t[i-1]-k]);
				ans = max(ans, dp[i][j]);
			}
	printf("%d\n", ans);
	
	return 0;
}

 

 

转载于:https://www.cnblogs.com/sugewud/p/9819421.html

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/107345.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • javascript学习目录

    javascript学习目录

    2022年3月1日
    87
  • python 获取时间戳_python将日期转换成时间戳

    python 获取时间戳_python将日期转换成时间戳1、获取秒级、毫秒级和微秒级时间戳importtimeimportdatetimet=time.time()#当前时间print(t)#原始时间数据print(int(t))#秒级时间戳print(int(round(t*1000)))#毫秒级时间戳print(int(round(t*1000000)))#微秒级时间戳结果:1634191096.03610181634191096163419109603616341910960361

    2022年9月3日
    4
  • RPC是什么意思_sata2和sata3接口区别

    RPC是什么意思_sata2和sata3接口区别http和rpc特点区别

    2022年10月13日
    0
  • win32怎么用_win32function failed

    win32怎么用_win32function failedHWNDhwndFound//=FindWindow(_T("RC352_Win32"),NULL); =GetConsoleWindow();

    2022年8月5日
    4
  • wireshark怎么抓包保存_wireshark保存抓包信息

    wireshark怎么抓包保存_wireshark保存抓包信息wireshark抓包使用wireshark抓包分析-抓包实用技巧前言本文整理一下日常抓包使用的一些方法及抓包分析的一些方法。本文基于wireshark2.2.6版本进行抓包处理。其他版本使用方式大同小异。自定义捕获条件wireshark可以将抓包数据保存到硬盘上。若需要长时间抓包的话,需要防止内存过大,因此一般需要指定一定大小切包,释放内存。在捕获-选项菜单中可以设置捕获包的一些配置。输入配置在…

    2022年9月6日
    2
  • js常用跳转代码[通俗易懂]

    js常用跳转代码[通俗易懂]今天整理下我们常用的js跳转代码,常用的js跳转代码比如:js倒计时跳转代码、pc站跳转手机站代码、在原来的窗体中直接js跳转用、在新窗体中打开页面用、js直接跳转代码、js返回代码、head标签内加如下代码实现页面定时自动跳转代码、self.location方式实现页面跳转、top.loca…

    2022年8月13日
    3

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号