hdoj1176 免费馅饼(dp 数塔)

题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1176

思路:

这道题不复杂,很明显是个dp题,数据比较大,搜索应该会超时,想到如何初始化,注意细节就差不多了。定义dp数组,边输入边初始化,dp[i][j]表示第i秒j处的掉落馅饼个数。dp过程从最后一秒逆向进行更方便,过程中dp[i][j]表示逆向到第i秒j处得到馅饼的最大值。有个坑点:最后输入的一组数据的时间不一定是最后一秒,我在这wa了一发。详见代码:

 1 #include<bits/stdc++.h>
 2 using namespace std;
 3
 4 int n,x,t,tt,dp[100005][15];
 5
 6 int main(){
 7     while(scanf("%d",&n)!=EOF&&n){
 8         memset(dp,0,sizeof(dp));
 9         tt=0;
10         while(n--){
11             scanf("%d%d",&x,&t);
12             if(t>tt) tt=t;
13             dp[t][x]++;
14         }
15         for(int i=tt-1;i>=0;i--)
16             for(int j=0;j<=10;j++){
17                 if(j==0) dp[i][j]+=max(dp[i+1][j],dp[i+1][j+1]);
18                 else if(j==10) dp[i][j]+=max(dp[i+1][j-1],dp[i+1][j]);
19                 else dp[i][j]+=max(dp[i+1][j-1],max(dp[i+1][j],dp[i+1][j+1]));
20             }
21         printf("%d\n",dp[0][5]);
22     }
23     return 0;
24 }

原文地址:https://www.cnblogs.com/FrankChen831X/p/10393303.html

时间: 2024-10-05 07:08:35

hdoj1176 免费馅饼(dp 数塔)的相关文章

hdu 1176 免费馅饼 (dp 数塔类型)

免费馅饼 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others) Total Submission(s): 25712    Accepted Submission(s): 8760 Problem Description 都说天上不会掉馅饼,但有一天gameboy正走在回家的小径上,忽然天上掉下大把大把的馅饼.说来gameboy的人品实在是太好了,这馅饼别处都不掉,就掉落在他身旁的1

HDU 1176免费馅饼 DP数塔问题转化

L - 免费馅饼 Time Limit:1000MS     Memory Limit:32768KB     64bit IO Format:%I64d & %I64u Submit Status Practice HDU 1176 Appoint description:  prayerhgq  (2015-07-28) System Crawler  (2015-11-21) Description 都说天上不会掉馅饼,但有一天gameboy正走在回家的小径上,忽然天上掉下大把大把的馅饼.

hdu1176 免费馅饼 ( 数塔(DP))

免费馅饼 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others) Total Submission(s): 32770    Accepted Submission(s): 11169 Problem Description 都说天上不会掉馅饼,但有一天gameboy正走在回家的小径上,忽然天上掉下大把大把的馅饼.说来gameboy的人品实在是太好了,这馅饼别处都不掉,就掉落在他身旁的

HDU1176_免费馅饼【数塔】

免费馅饼 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others) Total Submission(s): 26163    Accepted Submission(s): 8920 Problem Description 都说天上不会掉馅饼,但有一天gameboy正走在回家的小径上,忽然天上掉下大把大把的馅饼.说来gameboy的人品实在是太好了,这馅饼别处都不掉,就掉落在他身旁的1

HDOJ1176 免费馅饼 【DP】+【经典数塔】

免费馅饼 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others) Total Submission(s): 23986    Accepted Submission(s): 8093 Problem Description 都说天上不会掉馅饼,但有一天gameboy正走在回家的小径上,忽然天上掉下大把大把的馅饼.说来gameboy的人品实在是太好了,这馅饼别处都不掉,就掉落在他身旁的1

HDU2084基础DP数塔

数塔 Time Limit: 1000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total Submission(s): 33850    Accepted Submission(s): 20206 Problem Description 在讲述DP算法的时候,一个经典的例子就是数塔问题,它是这样描述的: 有如下所示的数塔,要求从顶层走到底层,若每一步只能走到相邻的结点,则经过的结点的数字之和最大是多少?

hdu 1176 dp 数塔问题

哎,一开始没看到从5开始.... 后来写懵了,用了queue正推,记录能到达的节点,p[i+1][j] = max(p[i][j],max(p[i][j-1],p[i][j+1])) 嗯,用stl mle了,自己写queue又tle,不知道为什么嚒,好像bfs我从没a过... 看了dicuss的思路,只看到数塔两个字我就懂了... 只能说巧妙了,区间反向确定我确实没想到... //数塔问题 /* t=0 5 t=1 456 t=2 34567 t=3 2345678 t=4 123456789

HDU1176 DP 数塔

看了大牛的代码后恍然大悟,然后自己开始写,WA了一下午! 这里有两个坑,让我找了一下午! AC代码: #include <iostream>#include <stdio.h>#include <stdlib.h>#include<string.h>#include<iostream>#include<string.h>#include<algorithm>const int maxn = 100000+5;int dp[

hdu 1176 免费馅饼 (dp)

http://acm.hdu.edu.cn/showproblem.php?pid=1176 #include<cstdio> #include<cstring> #include<iostream> #include<algorithm> using namespace std; int dp[100000+10][12]; int mat[100000+10][12]; int main() { int n; int i,j,k; int maxt; w