青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

oyjpArt ACM/ICPC算法程序設計空間

// I am new in programming, welcome to my blog
I am oyjpart(alpc12, 四城)
posts - 224, comments - 694, trackbacks - 0, articles - 6

PKU1925 Spiderman 【DP】

Posted on 2007-04-05 20:41 oyjpart 閱讀(2342) 評論(2)  編輯 收藏 引用 所屬分類: ACM/ICPC或其他比賽

Spiderman
Time Limit:5000MS  Memory Limit:65536K
Total Submit:1762 Accepted:197

Description
Dr. Octopus kidnapped Spiderman's girlfriend M.J. and kept her in the West Tower. Now the hero, Spiderman, has to reach the tower as soon as he can to rescue her, using his own weapon, the web.

From Spiderman's apartment, where he starts, to the tower there is a straight road. Alongside of the road stand many tall buildings, which are definitely taller or equal to his apartment. Spiderman can shoot his web to the top of any building between the tower and himself (including the tower), and then swing to the other side of the building. At the moment he finishes the swing, he can shoot his web to another building and make another swing until he gets to the west tower. Figure-1 shows how Spiderman gets to the tower from the top of his apartment – he swings from A to B, from B to C, and from C to the tower. All the buildings (including the tower) are treated as straight lines, and during his swings he can't hit the ground, which means the length of the web is shorter or equal to the height of the building. Notice that during Spiderman's swings, he can never go backwards.


You may assume that each swing takes a unit of time. As in Figure-1, Spiderman used 3 swings to reach the tower, and you can easily find out that there is no better way.

 

Input
The first line of the input contains the number of test cases K (1 <= K <= 20). Each case starts with a line containing a single integer N (2 <= N <= 5000), the number of buildings (including the apartment and the tower). N lines follow and each line contains two integers Xi, Yi, (0 <= Xi, Yi <= 1000000) the position and height of the building. The first building is always the apartment and the last one is always the tower. The input is sorted by Xi value in ascending order and no two buildings have the same X value.

Output
For each test case, output one line containing the minimum number of swings (if it's possible to reach the tower) or -1 if Spiderman can't reach the tower.

Sample Input

2
6
0 3
3 5
4 3
5 5
7 4
10 4
3
0 3
3 4
10 4

 

Sample Output

3
-1

 

Source
Beijing 2004 Preliminary@POJ

這是DP題,根據坐標DP是比較好的選擇,提交中wa多次。經回復指點 才注意到建筑物高度相乘越界了 謝謝提醒了

//Solution by oyjpArt
#include <stdio.h>
#include <math.h>
#include <string.h>
const int N = 5010;
const int M = 1000010;
int x[N], y[N], dp[M], nb;
const int MAXINT = 2000000000;
#define Min(a,b) ((a) < (b) ? (a) : (b))

int main() {
 int ntc, i, j;
 scanf("%d", &ntc);
 while(ntc--) {
  scanf("%d", &nb);
  for(i = 0; i<nb; i++)  scanf("%d %d", x+i, y+i);
  int m = x[nb-1];
  memset(dp, -1, (m+1)*sizeof(dp[0]));
  dp[x[0]] = 0;
  double h = y[0]; 
  for(i = 1; i<nb; i++) { //以1..i的建筑為中介進行飛行
   int d = sqrt(2*y[i]*h - h*h); //不會墜落到地上的最長距離 sqrt(y[i]*y[i]-sqare(y[i]-h))
   for(j = 1; j<=d; j++) { //DP
    if(x[i]-j < x[0]) break; //無用狀態
    if(dp[x[i]-j] == -1) continue; //不可達
    int k = x[i]+j < m ? x[i]+j : m;
    if(dp[k] == -1) dp[k] = dp[x[i]-j]+1;
    else dp[k] = Min(dp[k], dp[x[i]-j]+1);
   }//for
  }//for
  printf("%d\n", dp[m]);
 }
 return 0;
}

Feedback

# re: PKU1925 Spiderman 【DP】  回復  更多評論   

2007-04-11 15:24 by mark
int的話相乘后可能越界了

# re: PKU1925 Spiderman 【DP】  回復  更多評論   

2007-04-16 20:53 by oyjpart
謝謝提醒 呵呵
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            欧美在线视屏| 免费观看在线综合色| 国产精品人成在线观看免费 | 欧美在线视频一区二区| 亚洲婷婷综合久久一本伊一区| 国产精品成人aaaaa网站| 中文国产成人精品久久一| 一本色道久久99精品综合| 国产精品国产三级国产专播品爱网 | 久久综合色8888| 麻豆国产精品一区二区三区| 一本大道久久a久久精二百| 99re6这里只有精品| 国产精品毛片高清在线完整版| 久久成人国产| 女女同性精品视频| 亚洲伊人观看| 久久久久成人精品| 一区二区三区四区五区在线| 亚洲欧美视频在线观看| 亚洲高清不卡av| 在线亚洲自拍| 在线观看不卡| 亚洲视频欧洲视频| 亚洲第一毛片| 亚洲免费网址| 99精品国产高清一区二区| 性欧美大战久久久久久久免费观看 | 欧美电影电视剧在线观看| 欧美日本成人| 久久精品国产综合| 欧美岛国激情| 久久女同互慰一区二区三区| 欧美日韩国产综合视频在线| 久久婷婷久久一区二区三区| 欧美精品一区二区在线观看 | 国产精品久久久免费| 老司机久久99久久精品播放免费| 欧美精品18| 久久色在线观看| 欧美视频在线免费| 亚洲国产免费看| 国外精品视频| 亚洲免费人成在线视频观看| 一区二区欧美在线| 麻豆精品网站| 久久美女性网| 国产精品欧美一区二区三区奶水 | 亚洲高清在线视频| 亚洲一区在线免费| 99国产精品久久久久老师 | 久久伊人免费视频| 国产精品区一区二区三区| 亚洲欧洲在线一区| 亚洲欧洲日产国码二区| 久久精品中文| 老司机成人网| 激情六月婷婷久久| 午夜一级久久| 久久成人国产| 国产欧美视频一区二区三区| 亚洲天堂第二页| 亚洲女人天堂成人av在线| 欧美裸体一区二区三区| 亚洲动漫精品| 亚洲免费电影在线观看| 欧美国产日本韩| 91久久亚洲| 一本大道av伊人久久综合| 欧美人妖另类| 一二三区精品福利视频| 亚洲一区中文字幕在线观看| 国产精品久久| 欧美一区二区三区久久精品茉莉花 | 免费成人高清在线视频| 免费久久99精品国产自在现线| 精品成人乱色一区二区| 久久久国产一区二区| 美女尤物久久精品| 亚洲区一区二区三区| 欧美精品不卡| 亚洲天堂av在线免费| 亚洲欧美中日韩| 国产无一区二区| 久久一区二区三区国产精品| 亚洲国产高清高潮精品美女| 日韩视频一区二区三区| 欧美日韩在线一二三| 午夜日韩视频| 欧美不卡在线| 亚洲视频导航| 国产欧美一区二区精品性色| 久久国产精品黑丝| 亚洲成色最大综合在线| 亚洲私人影院在线观看| 国产视频一区在线| 麻豆亚洲精品| 亚洲婷婷综合久久一本伊一区| 久久天天躁狠狠躁夜夜av| 91久久综合| 国产欧美日韩另类视频免费观看| 久久天天躁夜夜躁狠狠躁2022 | 亚洲国内精品在线| 欧美日韩亚洲成人| 欧美一区久久| 亚洲另类在线一区| 久久亚洲国产成人| 一区二区日韩免费看| 狠狠色2019综合网| 欧美日韩亚洲一区三区| 久久久精品一区| 在线性视频日韩欧美| 欧美成人午夜激情在线| 先锋影音国产一区| 亚洲美女在线视频| 狠久久av成人天堂| 国产精品视频午夜| 欧美精品少妇一区二区三区| 久久福利一区| 亚洲欧美第一页| 亚洲精品国产拍免费91在线| 久久婷婷色综合| 性欧美大战久久久久久久久| 亚洲日本va午夜在线电影| 国产一区二区高清| 国产精品分类| 欧美三日本三级少妇三2023| 六十路精品视频| 久久久精品动漫| 午夜精品一区二区在线观看| 99伊人成综合| 日韩一级成人av| 亚洲国产婷婷香蕉久久久久久| 鲁大师成人一区二区三区 | 国产日产亚洲精品| 欧美人体xx| 欧美黄色影院| 免费在线看一区| 裸体一区二区三区| 久久天天综合| 老司机一区二区三区| 久久精品理论片| 久久精品视频在线看| 欧美一区视频在线| 欧美影院成年免费版| 亚洲欧美日韩一区| 午夜精品久久| 午夜宅男久久久| 欧美在线一级视频| 欧美在线免费观看| 久久久福利视频| 久久中文在线| 欧美国产日韩精品免费观看| 欧美另类一区| 国产精品国产自产拍高清av| 欧美午夜精品理论片a级按摩 | 亚洲精品欧美日韩专区| 亚洲黑丝一区二区| 亚洲伦理在线| 亚洲图片欧美日产| 亚洲欧美怡红院| 久久精品盗摄| 蜜臀av一级做a爰片久久| 你懂的国产精品| 欧美裸体一区二区三区| 国产精品久久久对白| 国产欧美一区二区三区国产幕精品| 国产亚洲欧美另类中文| 激情偷拍久久| av成人黄色| 午夜亚洲一区| 蜜桃视频一区| 亚洲伦理精品| 香蕉国产精品偷在线观看不卡 | 美女国内精品自产拍在线播放| 欧美国产在线观看| 亚洲欧洲一级| 香蕉视频成人在线观看| 久久精品夜色噜噜亚洲aⅴ| 欧美国产日韩在线| 国产日韩欧美二区| 亚洲另类春色国产| 欧美主播一区二区三区美女 久久精品人| 久久久久久高潮国产精品视| 亚洲人成人99网站| 性欧美videos另类喷潮| 欧美国产日韩视频| 国产一区二区三区丝袜 | 欧美成人午夜激情视频| 国产精品国产三级国产aⅴ9色| 一区二区视频欧美| 亚洲视频播放| 欧美激情1区2区| 香蕉成人伊视频在线观看| 欧美国产亚洲精品久久久8v| 激情六月综合| 欧美一区二区私人影院日本 | 亚洲精品美女在线| 久久精品一级爱片| 在线视频一区观看|