POJ:2385-Apple Catching(dp经典题)
Apple Catching
Time Limit: 1000MS Memory Limit: 65536K
Total Submissions: 14311 Accepted: 7000
Description
It is a little known fact that cows love apples. Farmer John has two apple trees (which are conveniently numbered 1 and 2) in his field, each full of apples. Bessie cannot reach the apples when they are on the tree, so she must wait for them to fall. However, she must catch them in the air since the apples bruise when they hit the ground (and no one wants to eat bruised apples). Bessie is a quick eater, so an apple she does catch is eaten in just a few seconds.
Each minute, one of the two apple trees drops an apple. Bessie, having much practice, can catch an apple if she is standing under a tree from which one falls. While Bessie can walk between the two trees quickly (in much less than a minute), she can stand under only one tree at any time. Moreover, cows do not get a lot of exercise, so she is not willing to walk back and forth between the trees endlessly (and thus misses some apples).
Apples fall (one each minute) for T (1 <= T <= 1,000) minutes. Bessie is willing to walk back and forth at most W (1 <= W <= 30) times. Given which tree will drop an apple each minute, determine the maximum number of apples which Bessie can catch. Bessie starts at tree 1.
Input
Line 1: Two space separated integers: T and W
Lines 2..T+1: 1 or 2: the tree that will drop an apple each minute.
Output
- Line 1: The maximum number of apples Bessie can catch without walking more than W times.
Sample Input
7 2
2
1
1
2
2
1
1
Sample Output
6
Hint
INPUT DETAILS:
Seven apples fall - one from tree 2, then two in a row from tree 1, then two in a row from tree 2, then two in a row from tree 1. Bessie is willing to walk from one tree to the other twice.
OUTPUT DETAILS:
Bessie can catch six apples by staying under tree 1 until the first two have dropped, then moving to tree 2 for the next two, then returning back to tree 1 for the final two.
解题心得:
- 题意就是有两颗苹果树,每一秒钟某一颗树上会掉下来一颗苹果,一个人可以在两棵树下移动,移动时间不计,最多可以移动k次,问这个人最多可以获得多少颗苹果。
- 其实这个题最直观的做法就是用记忆化搜索,直接按照题意搜索就行了。当然也可以将记忆化搜索提炼出dp公式出来,写dp状态转移方程式。
- 提炼出来dp方程式可以这样表示,dp[i][j]为在i秒最多移动j次可以获得的最大苹果树。状态转移方程为dp[i][j] = max(dp[i-1][j],dp[i-1][j-1]) + (j%2+1 == arr[i]),因为一开始在1位置,所以在移动j次之后所在的位置为j%2+1,代表在第i秒移动j次的状态只能够从第i-1秒移动j-1次和i-1秒移动j次转移而来,然后加上当前是否可以接到苹果的。
记忆化搜索代码:
#include <algorithm>
#include <stdio.h>
#include <cstring>
using namespace std;
const int maxn = 1010;
int dp[maxn][35][3],w,n,scor[maxn];
void init() {
memset(dp,-1,sizeof(dp));
scanf("%d%d",&n,&w);
for(int i=1;i<=n;i++) {
scanf("%d",&scor[i]);
scor[i] %= 2;
}
}
int dfs(int times,int change,int pos) {
if(times > n || change > w)
return 0;
if(dp[times][change][pos] != -1)
return dp[times][change][pos];
return dp[times][change][pos] = ((scor[times] == pos) + max(dfs(times+1,change,pos),dfs(times+1,change+1,!pos)));
}
int main() {
init();
int ans = max(dfs(1,0,1),dfs(1,0,0));
printf("%d\n",ans);
return 0;
}
dp方程式转移代码
#include <stdio.h>
#include <algorithm>
using namespace std;
const int maxn = 1010;
int dp[maxn][35];
int arr[maxn];
int main() {
int n,k;
scanf("%d%d",&n,&k);
for(int i=1;i<=n;i++)
scanf("%d",&arr[i]);
for(int i=1;i<=n;i++) {
for(int j=0;j<=k;j++) {
if(j == 0) {
dp[i][j] = dp[i-1][j] + (j%2 +1 == arr[i]);
continue;
}
dp[i][j] = max(dp[i-1][j],dp[i-1][j-1]);
if(j%2 + 1 == arr[i])
dp[i][j]++;
}
}
int ans = 0;
for(int i=0;i<=k;i++)
ans = max(ans,dp[n][i]);
printf("%d\n",ans);
return 0;
}
POJ:2385-Apple Catching(dp经典题)的更多相关文章
- poj 2385 Apple Catching(dp)
Description It and ) in his field, each full of apples. Bessie cannot reach the apples when they are ...
- poj 2385 Apple Catching 基础dp
Apple Catching Description It is a little known fact that cows love apples. Farmer John has two ap ...
- POJ 2385 Apple Catching【DP】
题意:2棵苹果树在T分钟内每分钟随机由某一棵苹果树掉下一个苹果,奶牛站在树#1下等着吃苹果,它最多愿意移动W次,问它最多能吃到几个苹果.思路:不妨按时间来思考,一给定时刻i,转移次数已知为j, 则它只 ...
- POJ 2385 Apple Catching ( 经典DP )
题意 : 有两颗苹果树,在 1~T 的时间内会有两颗中的其中一颗落下一颗苹果,一头奶牛想要获取最多的苹果,但是它能够在树间转移的次数为 W 且奶牛一开始是在第一颗树下,请编程算出最多的奶牛获得的苹果数 ...
- POJ - 2385 Apple Catching (dp)
题意:有两棵树,标号为1和2,在Tmin内,每分钟都会有一个苹果从其中一棵树上落下,问最多移动M次的情况下(该人可瞬间移动),最多能吃到多少苹果.假设该人一开始在标号为1的树下. 分析: 1.dp[x ...
- POJ 2385 Apple Catching
比起之前一直在刷的背包题,这道题可以算是最纯粹的dp了,写下简单题解. 题意是说cows在1树和2树下来回移动取苹果,有移动次数限制,问最后能拿到的最多苹果数,含有最优子结构性质,大致的状态转移也不难 ...
- poj 2385 Apple Catching(记录结果再利用的动态规划)
传送门 https://www.cnblogs.com/violet-acmer/p/9852294.html 题意: 有两颗苹果树,在每一时刻只有其中一棵苹果树会掉苹果,而Bessie可以在很短的时 ...
- POJ 2385 Apple Catching(01背包)
01背包的基础上增加一个维度表示当前在的树的哪一边. #include<cstdio> #include<iostream> #include<string> #i ...
- 【POJ】2385 Apple Catching(dp)
Apple Catching Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 13447 Accepted: 6549 D ...
随机推荐
- vue打包后CSS中引用的背景图片不显示问题
vue项目中,在css样式中引用了一张背景图片,开发环境下是可以正常显示,build之后背景图片不显示. 解决方法: 找到build/utils.js文件 修改成为如下所示内容: 添加红框中的内容即 ...
- Java Knowledge series 4
JVM & Bytecode Has-a or Is-a relationship(inheritance or composition) 如果想利用新类内部一个现有类的特性,而不想使用它的接 ...
- Azure IOT 设备固件更新技巧,看这一篇就够了
嫌长不看版 今天为大家准备的硬菜是:在 Azure IoT 中心创建 Node.js 控制台应用,进行端到端模拟固件更新,为基于 Intel Edison 的设备安装新版固件的流程.通过创建模拟设备应 ...
- javaWeb上移下移(SpringMVC+Mabits+MySql)
文章已移至:https://blog.csdn.net/baidu_35468322/article/details/79643356 移动之前: 移动之后: 1.控制层 /** * 修改排序 * * ...
- shell脚本学习(1)列出一组IP内所有活动主机
1.用ping命令编写脚本来查询一组IP地址同时检查他们是否处于活动状态 [zhi@centos7 ~]$ vi CheckHostStatus.sh [zhi@centos7 ~]$ ll 总用量 ...
- ubuntu安装rpm包,deb包等各种包
ubuntu下的各种包的安装方法 Ubuntu麒麟自带的包管理工具有apt-get,但是里面的软件包一般年代比较久远,源更新很慢,支持也很少.如果想安装一些比较新的包,可以尝试到PPA上去找找看,找到 ...
- Lubuntu , ubuntu 搜索文件
使用命令行方式搜索 $ locate your_filename
- thinkphp 去掉URL 里面的index.php
例如你的原路径是 http://localhost/test/index.php/home/goods/index.html 那么现在的地址是 http://localhost/test/home/g ...
- 【[TJOI2017]DNA】
[题目][https://www.lydsy.com/JudgeOnline/problem.php?id=4892] 好像用\(SAM\)做的都是\(dfs\)啊 其实这里也是搜索 如果用\(SAM ...
- C++STL之map映照容器
map映照容器 map映照容器的元素数据是由一个键值和一个映照数据组成的, 键值与映照数据之间具有一一映照关系. map映照容器的数据结构也是采用红黑树来实现的, 插入元素的键值不允许重复, 比较函数 ...