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

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

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

PKU 1328 Radar Installation

Posted on 2007-06-22 20:00 oyjpart 閱讀(3004) 評論(0)  編輯 收藏 引用 所屬分類: ACM/ICPC或其他比賽

Radar Installation
Time Limit:1000MS  Memory Limit:10000K
Total Submit:2704 Accepted:564

Description
Assume the coasting is an infinite straight line. Land is in one side of coasting, sea in the other. Each small island is a point locating in the sea side. And any radar installation, locating on the coasting, can only cover d distance, so an island in the sea can be covered by a radius installation, if the distance between them is at most d.

We use Cartesian coordinate system, defining the coasting is the x-axis. The sea side is above x-axis, and the land side below. Given the position of each island in the sea, and given the distance of the coverage of the radar installation, your task is to write a program to find the minimal number of radar installations to cover all the islands. Note that the position of an island is represented by its x-y coordinates.


Figure A Sample Input of Radar Installations



 

Input
The input consists of several test cases. The first line of each case contains two integers n (1<=n<=1000) and d, where n is the number of islands in the sea and d is the distance of coverage of the radar installation. This is followed by n lines each containing two integers representing the coordinate of the position of each island. Then a blank line follows to separate the cases.

The input is terminated by a line containing pair of zeros

Output
For each test case output one line consisting of the test case number followed by the minimal number of radar installations needed. "-1" installation means no solution for that case.

Sample Input

3 2
1 2
-3 1
2 1
1 2
0 2
0 0

 

Sample Output

Case 1: 2
Case 2: 1

 

Source
Beijing 2002


Algorithm: Greedy
Step 1: 輸入數據 如果有一個點的y坐標大于d 直接輸出-1 長生相應的區間(在某一個區間里任意放置一個Radar 則是這個Island可視)
Step 2: 按照左端點排序(如果左端點相等 則必須按右邊反向排序, 理由在于下一步為了篩選出包含的 必須的把大范圍的放到前面) 注意這里面最好要用浮點判斷規則
Step 3: 利用Stack對這些區間做預處理 把被包含的區間標識出來
Step 4: 貪心選擇右端的點

#include <stdio.h>
#include <string.h>
#include <algorithm>
#include <math.h>
using namespace std;

const int N = 1000;
const double EPS = 1e-7;

struct E { double a, b; } e[N];
int n, d;
bool ava[N];
double p[N];

inline int dblcmp(double a, double b) {
 if( fabs(a-b) < EPS ) return 0;
 if( a-b > 0 ) return 1;
 return -1;
}

bool operator<(const E& a, const E& b) {
 if(dblcmp(a.a, b.a) == 0)
  return dblcmp(a.b, b.b) == 1;
 return dblcmp(a.a, b.a) == -1;
}


int main() {
 int i, j, x, y;
 int tc = 0;
 while(scanf("%d %d", &n, &d), n + d) {
  tc++;
  int ok = 1;
  for(i = 0; i < n; ++i) {
   scanf("%d %d", &x, &y);
   if(y > d) ok = 0;
   double offset = sqrt ( d * d - y * y );
   e[i].a = x - offset, e[i].b = x + offset;
   ava[i] = 1;
  }
  if(!ok) { printf("Case %d: -1\n", tc); continue; }
  sort(e, e + n);
  int stack[N], top = 0;
  stack[top++] = 0;
  for(i = 1; i < n; ++i) {
   while(top > 0 && dblcmp(e[stack[top-1]].b, e[i].b) != -1)  {
    ava[stack[--top]] = 0;
   }
   stack[top++] = i;
  }
  
  for(i = 0; !ava[i]; ++i);
  p[i] = e[i].b;
  int cnt = 1;
  for(i = i+1; i < n; ++i) if(ava[i]) {
   for(j = i-1; !ava[j]; j--);
   if(p[j] >= e[i].a)  p[i] = p[j];
   else { p[i] = e[i].b; cnt++; }
  }
  printf("Case %d: %d\n", tc, cnt);
 }
 return 0;
}

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            久久久久久久网| 老牛国产精品一区的观看方式| 亚洲国产高清在线观看视频| 久久狠狠婷婷| 亚洲第一中文字幕| 亚洲国产精品成人综合色在线婷婷| 久久精品国产免费| 亚洲国产小视频| 亚洲国产视频一区| 欧美天堂亚洲电影院在线观看| 亚洲男人的天堂在线aⅴ视频| 亚洲视频久久| 国产中文一区二区| 欧美大片免费观看| 欧美精品一区三区| 亚洲一区二区三区高清| 亚洲永久精品大片| 一区二区三区在线不卡| 亚洲国产另类精品专区| 欧美偷拍另类| 久久五月激情| 欧美日韩国产成人高清视频| 亚洲欧美久久久久一区二区三区| 欧美一级大片在线观看| 亚洲国产精品成人精品| 亚洲最新合集| 狠狠综合久久| 一本色道久久综合亚洲精品不卡| 国产午夜一区二区三区| 亚洲高清资源| 国产午夜久久| 99在线|亚洲一区二区| 国产一区在线播放| 夜夜爽www精品| **欧美日韩vr在线| 中国亚洲黄色| 亚洲日本激情| 欧美在线|欧美| 亚洲一二三区精品| 美脚丝袜一区二区三区在线观看 | 日韩午夜在线视频| 亚洲欧美日韩一区在线观看| 亚洲人成网站在线播| 先锋影音网一区二区| 亚洲一区制服诱惑| 欧美激情第8页| 欧美激情国产日韩| 国产一区二区三区av电影| 亚洲精品日韩精品| 亚洲品质自拍| 久久久久**毛片大全| 亚洲欧美日韩爽爽影院| 欧美日本一区二区高清播放视频| 欧美成人精品三级在线观看| 国产日韩综合| 午夜精品视频网站| 亚洲自拍偷拍麻豆| 欧美日韩在线不卡一区| 亚洲福利视频网| 在线成人欧美| 久久女同精品一区二区| 久久久一本精品99久久精品66| 国产精品嫩草久久久久| 99热这里只有精品8| av成人免费在线| 欧美日韩喷水| 日韩香蕉视频| 宅男精品视频| 国产精品第13页| 亚洲一区二区三区精品视频| 亚洲一区二区三区四区五区午夜| 欧美日韩国产免费| 亚洲伦理在线| 亚洲欧美区自拍先锋| 国产精一区二区三区| 午夜欧美视频| 久久一区二区三区av| 在线日本成人| 欧美激情在线| 在线视频一区观看| 欧美一区二区免费视频| 国产日韩欧美中文| 久久黄色级2电影| 欧美 亚欧 日韩视频在线| 亚洲韩国精品一区| 欧美日韩一区二区高清| 亚洲视频一区二区| 久久久激情视频| 亚洲国产日韩欧美在线动漫| 欧美精品在线免费播放| 中文国产一区| 裸体一区二区三区| 亚洲精品一线二线三线无人区| 欧美日韩精品三区| 亚洲欧美激情视频| 欧美sm重口味系列视频在线观看| 日韩午夜一区| 国产一区自拍视频| 欧美激情四色| 欧美一二区视频| 亚洲国产二区| 欧美资源在线| 亚洲精品一区久久久久久| 国产精品久久久久久久久久久久 | 中国成人在线视频| 久久蜜桃香蕉精品一区二区三区| 亚洲三级性片| 国产日韩欧美一二三区| 欧美激情综合网| 欧美一区二区三区在线看| 亚洲欧洲日本一区二区三区| 久久成人精品| 国产精品99久久久久久久女警 | 国产精品自拍网站| 欧美.www| 久久久精品一区| 亚洲一区二区三区四区视频| 欧美国产高清| 久久久不卡网国产精品一区| 一本色道综合亚洲| 伊人激情综合| 国产无一区二区| 欧美日韩综合久久| 欧美成人免费va影院高清| 性做久久久久久久免费看| 亚洲免费电影在线观看| 欧美成人免费网站| 久久视频国产精品免费视频在线| 亚洲一区二区成人| 亚洲精品综合精品自拍| 亚洲第一毛片| 影音先锋中文字幕一区| 国产一区二区黄| 国产精品夜夜嗨| 国产精品久久国产精品99gif | 蜜桃av噜噜一区| 久久国产精品久久精品国产| 亚洲欧美日韩综合| 亚洲视频免费看| 国产精品99久久久久久白浆小说| 亚洲三级观看| 亚洲成色777777女色窝| 欧美成人亚洲成人| 欧美国产日韩一区二区三区| 久久久999国产| 久久久99国产精品免费| 久久精品欧美| 久久青青草原一区二区| 久久久久成人精品| 久久一日本道色综合久久| 久久九九久久九九| 久久综合久久综合九色| 你懂的视频欧美| 亚洲电影在线免费观看| 亚洲欧洲日韩女同| 一本一本久久a久久精品综合麻豆 一本一本久久a久久精品牛牛影视 | 亚洲小视频在线观看| 这里是久久伊人| 亚洲欧美综合v| 久久国产成人| 女同一区二区| 欧美88av| 欧美色视频一区| 国产一区二区三区久久悠悠色av | 国产一区二区三区四区hd| 国产在线不卡| 在线观看国产成人av片| 亚洲欧洲综合| 亚洲手机在线| 久久午夜视频| 91久久精品国产91久久| 99这里只有久久精品视频| 亚洲欧美在线免费观看| 久久免费视频这里只有精品| 欧美激情一区二区三区在线| 国产精品久久久久久久免费软件 | 免费亚洲电影在线观看| 欧美日韩天堂| 国内精品久久久久久久果冻传媒| 亚洲国产精品va在线观看黑人| 在线视频精品一区| 久久久噜噜噜| 亚洲狼人综合| 久久久亚洲国产天美传媒修理工| 欧美全黄视频| 1024亚洲| 久久成年人视频| 亚洲电影在线观看| 午夜久久久久久| 欧美日韩国产高清| 狠狠色狠狠色综合日日小说| 99re亚洲国产精品| 久久夜色精品国产欧美乱| 日韩一区二区精品| 久久综合999| 国产毛片一区二区| 一本大道久久精品懂色aⅴ| 久久久精品一区| 一区二区三区视频在线看| 女人色偷偷aa久久天堂|