zoukankan      html  css  js  c++  java
  • 位置判断poj 1925 spiderman

    这两天一直在查找位置判断之类的问题,上午正好有机会和大家讨论一下.

        这个标题无疑我被坑惨了,就是因为这个问题丫的一个序程,这么写

        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[n]&&(dp[p[n]]==-1||dp[p[n]]>dp[aim]))
    					dp[p[n]]=dp[aim];//边界理处
    			}
    		if(dp[p[n]]<=0)
    			cout<<"-1";
    		else cout<<dp[p[n]];
    		cout<<endl;
    		t=t-1;
    	}
    	return 0;
    }

        
     

    文章结束给大家分享下程序员的一些笑话语录: 腾讯的动作好快,2010年3月5日19时28分58秒,QQ同时在线人数1亿!刚刚看到编辑发布的文章,相差才2分钟,然后连专题页面都做出来了,他们早就预料到了吧?(其实,每人赠送10Q币,轻轻松松上两亿!)

  • 相关阅读:
    FFT加速多项式乘法C语言版(基2FFT)
    springboot2中@ConfigurationProperties装载yml文件的时候调取出现值为null的解决办法
    LeetCode27-移除元素
    dom4j在解析xml文件的时候将" "解析成空格的解决办法
    LeetCode17- 电话号码的字母组合
    LeetCode19- 删除链表的倒数第N个节点
    LeetCode14- 最长公共前缀
    LeetCode20- 有效的括号
    LeetCode21- 合并两个有序链表
    MySQL单表百万数据记录分页性能优化
  • 原文地址:https://www.cnblogs.com/jiangu66/p/3061663.html
Copyright © 2011-2022 走看看