時間限制:
3000 ms | 記憶體限制:
65535 kb
難度:4 描述
有一塊草坪,橫向長w,縱向長為h,在它的橫向中心線上不同位置處裝有n(n<=10000)個點狀的噴水裝置,每個噴水裝置i噴水的效果是讓以它為中心半徑為ri的圓都被潤濕。請在給出的噴水裝置中選擇盡量少的噴水裝置,把整個草坪全部潤濕。
輸入第一行輸入乙個正整數n表示共有n次測試資料。
每一組測試資料的第一行有三個整數n,w,h,n表示共有n個噴水裝置,w表示草坪的橫向長度,h表示草坪的縱向長度。
隨後的n行,都有兩個整數xi和ri,xi表示第i個噴水裝置的的橫座標(最左邊為0),ri表示該噴水裝置能覆蓋的圓的半徑。
輸出每組測試資料輸出乙個正整數,表示共需要多少個噴水裝置,每個輸出單獨佔一行。
如果不存在一種能夠把整個草坪濕潤的方案,請輸出0。
樣例輸入
22 8 6
1 14 5
2 10 6
4 56 5
樣例輸出
12
**《演算法藝術與資訊學競賽》
上傳者
張云聰根據每個噴水裝置的橫座標和半徑算出其在橫的位置上所覆蓋的區間,然後對所有區間對左座標進行從小到大的排序,然後從第乙個區間開始,選擇與其相交且右座標最遠的區間,重複這個過程,直到右座標大於等於寬w。
#include
02.
#include
03.
#include
04.
using
namespace
std;
05.
06.
#define maxn 10004
07.
08.
struct
sprinkler
09.
spk[maxn];
13.
14.
bool
compare(
const
sprinkler &a,
const
sprinkler &b)
15.
18.
19.
int
main()
20.
39.
}
40.
sort(spk,spk+m,compare);
41.
if
(spk[0].left>0)
42.
cout<<0<
43.else
44.
60.
else
if
(spk[j].left>spk[i].right)
61.
break
;
62.
}
63.
if
(maxindex==i)
64.
break
;
65.
i=maxindex;
66.
}
67.
if
(maxright>=w)
68.
cout<
69.else
70.
cout<<0<
71.}
72.
}
73.
return
0;
74.
}
噴水裝置(二)
時間限制 3000 ms 記憶體限制 65535 kb 難度 4 描述 有一塊草坪,橫向長w,縱向長為h,在它的橫向中心線上不同位置處裝有n n 10000 個點狀的噴水裝置,每個噴水裝置i噴水的效果是讓以它為中心半徑為ri的圓都被潤濕。請在給出的噴水裝置中選擇盡量少的噴水裝置,把整個草坪全部潤濕。...
噴水裝置(二)
時間限制 3000 ms 記憶體限制 65535 kb 難度 4 描述 有一塊草坪,橫向長w,縱向長為h,在它的橫向中心線上不同位置處裝有n n 10000 個點狀的噴水裝置,每個噴水裝置i噴水的效果是讓以它為中心半徑為ri的圓都被潤濕。請在給出的噴水裝置中選擇盡量少的噴水裝置,把整個草坪全部潤濕。...
噴水裝置(二)
時間限制 3000 ms 記憶體限制 65535 kb 難度 4 描述 有一塊草坪,橫向長w,縱向長為h,在它的橫向中心線上不同位置處裝有n n 10000 個點狀的噴水裝置,每個噴水裝置i噴水的效果是讓以它為中心半徑為ri的圓都被潤濕。請在給出的噴水裝置中選擇盡量少的噴水裝置,把整個草坪全部潤濕。...