題目:平面上有n個圓,他們的圓心都在x軸上,給出所有圓的圓心和半徑,求有多少對圓是相離的。
例如:4個圓分別位於1, 2, 3, 4的位置,半徑分別為1, 1, 2, 1,那麼, 這5對都有交點,只有是相離的。
input
第1行:乙個數n,表示圓的數量(1 <= n <= 50000)output第2 - n + 1行:每行2個數p, r中間用空格分隔,p表示圓心的位置,r表示圓的半徑(1 <= p, r <= 10^9)
輸出共有多少對相離的圓。
先對終點排序,然後二分找終點大於起點的圓。
#include #include#define n 55000
#define inf 0x7ffffff
#define ll long long
using namespace std;
struct node
a[n];
bool cmp(node a,node b)
while(l>0&&a[l].y>=t) l--;
return l;
}int main()
a[0].x=a[0].y=-inf;
sort(a,a+n+1,cmp);
ll ans=0;
for(ll i=1;i<=n;i++)
ans+=_find(0,i-1,a[i].x);
cout<
51 NOD 1278 相離的圓
1278 相離的圓 基準時間限制 1 秒 空間限制 131072 kb 分值 10 難度 2級演算法題 平面上有n個圓,他們的圓心都在x軸上,給出所有圓的圓心和半徑,求有多少對圓是相離的。例如 4個圓分別位於1,2,3,4的位置,半徑分別為1,1,2,1,那麼,這5對都有交點,只有是相離的。inpu...
51Nod 1278 相離的圓
平面上有n個圓,他們的圓心都在x軸上,給出所有圓的圓心和半徑,求有多少對圓是相離的。例如 4個圓分別位於1,2,3,4的位置,半徑分別為1,1,2,1,那麼,這5對都有交點,只有是相離的。input 第1行 乙個數n,表示圓的數量 1 n 50000 第2 n 1行 每行2個數p,r中間用空格分隔,...
51Nod1278 相離的圓
平面上有n個圓,他們的圓心都在x軸上,給出所有圓的圓心和半徑,求有多少對圓是相離的。例如 4個圓分別位於1,2,3,4的位置,半徑分別為1,1,2,1,那麼,這5對都有交點,只有是相離的。注意圓心在座標軸上,之前因為沒看到這句話把題跳了。然後就可以轉化為線段,按照左端點排序,i代表線段迴圈,二分求左...