您的位置:首页 > 其它

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,那么必然这个你想推出的状态不是从这个来的。然后还有一点蜘蛛侠是不能碰到地面的,所以要判断一下。下面具体看程序。

#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;
}


 
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: