poj 1925 spiderman
2013-05-04 23:20
555 查看
这个题目无疑我被坑惨了,就是因为这个问题丫的一个程序,这么写
cin>>t;
while(t!=0){中间略过;t=t-1}就wa。
这么写
cin>>t;
while(t--){中间略过;}就AC。一晚上我写了10几遍啊。坑死了。
题目是好题,其实比较好想,这个与之前走过路有关。dp[i]表示跳到i位置的时候最少跳多少次,但是可能有的位置你跳不到,所以开始全部赋值为-1就好了,如果当前位置的dp为-1,那么必然这个你想推出的状态不是从这个来的。然后还有一点蜘蛛侠是不能碰到地面的,所以要判断一下。下面具体看程序。
cin>>t;
while(t!=0){中间略过;t=t-1}就wa。
这么写
cin>>t;
while(t--){中间略过;}就AC。一晚上我写了10几遍啊。坑死了。
题目是好题,其实比较好想,这个与之前走过路有关。dp[i]表示跳到i位置的时候最少跳多少次,但是可能有的位置你跳不到,所以开始全部赋值为-1就好了,如果当前位置的dp为-1,那么必然这个你想推出的状态不是从这个来的。然后还有一点蜘蛛侠是不能碰到地面的,所以要判断一下。下面具体看程序。
#include<iostream> #include<stdio.h> #include<cstring> using namespace std; const int MAX_X=2000000 + 5; int p[5005],h[5005]; int dp[MAX_X]; double scale[5005]; int main() { int n,t,i,j,aim; cin>>t; while(t!=0) { cin>>n; for(i=1;i<=n;i++) { scanf("%d%d",&p[i],&h[i]); scale[i]=h[i]*h[i]-(h[i]-h[1])*(h[i]-h[1]);//下面判断蜘蛛侠是不是能碰到地面 } memset(dp,-1,sizeof(int)*MAX_X); dp[p[1]]=0; for(i=2;i<=n;i++) for(j=p[i]-1;j>=p[1];j--) { if(dp[j]==-1)//这个状态是没有被开启的,直接跳过下面的部分 continue; int gap; gap=(p[i]-j); if(gap*gap>scale[i])//判断蜘蛛侠是不是能碰到地面 break; aim=2*p[i]-j;//从j位置起跳经过建筑物i的时候到达的目的地 if(dp[aim]==-1||dp[j]+1<dp[aim]) dp[aim]=dp[j]+1;//修改aim的dp if(aim>=p &&(dp[p ]==-1||dp[p ]>dp[aim])) dp[p ]=dp[aim];//边界处理 } if(dp[p ]<=0) cout<<"-1"; else cout<<dp[p ]; cout<<endl; t=t-1; } return 0; }
相关文章推荐
- poj-1925 Spiderman
- POJ 1925 Spiderman (DP)
- 位置判断poj 1925 spiderman
- [poj 1925] Spiderman 简单dp
- POJ-1925 Spiderman 动态规划
- 【poj 1925】Spiderman 题意&题解&代码(C++)
- POJ 1925 Spiderman
- POJ 1925 Spiderman(DP)
- 【POJ 1925】 Spiderman(dp)
- POJ 1925 Spiderman [DP]
- POJ 1925 Spiderman
- poj 1925 Spiderman
- POJ 1925 Spiderman
- POJ 1925 Spiderman(线性dp)
- poj 1925 spiderman
- poj 1925 Spiderman 动态规划
- poj1925-Spiderman(dp)
- poj 1925 Spiderman
- POJ 1925 Spiderman 笔记
- POJ 1925 Spiderman