码迷,mamicode.com
首页 > 移动开发 > 详细

poj 2385 树上掉苹果问题 dp算法

时间:2018-08-02 14:50:20      阅读:160      评论:0      收藏:0      [点我收藏+]

标签:要求   div   解决问题   span   输入   说明   小技巧   include   algorithm   

题意:有树1 树2 会掉苹果,奶牛去捡,只能移动w次,开始的时候在树1 问最多可以捡多少个苹果?

思路: dp[i][j]表示i分钟移动j次捡到苹果的最大值

实例分析 

  0,1  1,2...说明 偶数在树1 奇数在树2

    

for (int i = 1; i <= n; i++)
{
scanf("%d", &t[i]);
t[i] -= 1;
}
for (int i = 1; i <= n; i++)
for (int j = 0; j <= w; j++)
{
if (j % 2) dp[i][j] = max(dp[i - 1][j], dp[i - 1][j - 1]) + t[i];
else dp[i][j] = max(dp[i - 1][j], dp[i - 1][j - 1]) + !t[i];
}

这里有个小技巧,不是每次要求输入1 2 2 之类的数据,我们把它们都-1 然后就可以就比较好看了

解释一下两句dp语句

dp[i][j] = max(dp[i - 1][j], dp[i - 1][j - 1]) 表示上一次要么在树1 要么在树2的情况,但是我只需要它们两者之间的最大值

解决问题的代码:

#include <iostream>
#include <cstdio>
#include <algorithm>
using namespace std;
int dp[1010][35];
int t[1010];
int main()
{
    int n, w;
    scanf("%d%d", &n, &w);
    for (int i = 1; i <= n; i++)
    {
        scanf("%d", &t[i]);
        t[i] -= 1;
    }
    for (int i = 1; i <= n; i++)
        for (int j = 0; j <= w; j++)
        {
            if (j % 2) dp[i][j] = max(dp[i - 1][j], dp[i - 1][j - 1]) + t[i];
            else dp[i][j] = max(dp[i - 1][j], dp[i - 1][j - 1]) + !t[i];
        }
    printf("%d\n", dp[n][w]);
}

 

poj 2385 树上掉苹果问题 dp算法

标签:要求   div   解决问题   span   输入   说明   小技巧   include   algorithm   

原文地址:https://www.cnblogs.com/xuxiaojin/p/9406686.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!