description


analysis

  • 二分一个角度,首先假设该弧度角\(\theta \in[{\pi \over 2},\pi]\),要找的直线斜率\(k\in(-∞,\tan\theta]\)

  • 要找这种直线,两个点\((x_i,y_i),(x_j,y_j)\)构成一条直线,先钦定\(x_i≤x_j\)

  • 直线斜率\({{y_j-y_i}\over{x_j-x_i}}≤\tan\theta\),转化后变成\(y_j-x_j\tan\theta≤y_i-x_i\tan\theta\)

  • 因为两边分别只和\(i,j\)有关,可以把\(y_k-x_k\tan\theta\)记做\(yy_k\),\((x_i,y_i)\)映射到\((x_i,yy_i)\)

  • 此时就是要求有多少对点\(x_i≤x_j,yy_i≥yy_j\),二维偏序,用树状数组解决

  • 这种情况少计算了斜率为正的直线条数,需要把算少的这部分加起来

  • 那么对于\(\theta\in[0,{\pi \over 2})\),计算斜率小于\(\tan\theta\)的直线条数过程是完全一样的

  • 这种情况又多计算了斜率为负的直线条数,需要把算多的这部分减掉

  • 经过一个点有多少条直线斜率为正,就是一个点右上角的点个数;斜率为负就是左上角的点个数

  • 这个可以一开始用两次树状数组求出\(\sum\)右上角点个数和\(\sum\)左上角点个数

  • 由于二分区间不同,这里左上角右上角求的范围有一点点差别,左上角必须严格高于该点,右上角则否

  • 二分的时候判断当前在直线右手边的直线条数是否大于等于比较数,是则\(r\)右移,否则\(l\)左移

  • 注意取开闭区间和计算的小细节


code

#pragma GCC optimize("O3")
#pragma G++ optimize("O3")
#include<stdio.h>
#include<string.h>
#include<algorithm>
#include<math.h>
#define eps 1e-10
#define MAXN 100005
#define db double
#define ll long long
#define reg register ll
#define lowbit(x) ((x)&(-x))
#define pi 3.1415926535897932384626
#define fo(i,a,b) for (reg i=a;i<=b;++i)
#define fd(i,a,b) for (reg i=a;i>=b;--i) using namespace std; ll tr[MAXN],sum[MAXN];
ll n,m,tot,summ1,summ2; struct node
{
ll x,y;
}a[MAXN];
struct node1
{
db x;ll y,val;
}b[MAXN];
inline ll read()
{
ll x=0,f=1;char ch=getchar();
while (ch<'0' || '9'<ch){if (ch=='-')f=-1;ch=getchar();}
while ('0'<=ch && ch<='9')x=x*10+ch-'0',ch=getchar();
return x*f;
}
inline bool cmp(node a,node b){return a.x<b.x || (a.x==b.x && a.y>b.y);}
inline bool cmp1(node1 a,node1 b){return a.x<b.x;}
inline bool cmp2(node1 a,node1 b){return a.y<b.y;}
inline void insert(ll x){while (x<=n)++tr[x],x+=lowbit(x);}
inline ll query(ll x){ll y=0;while (x)y+=tr[x],x-=lowbit(x);return y;}
inline ll get(ll x,ll y){return query(y)-query(x-1);}
inline db binary(db m)
{
db l=0,r=pi,mid,tann;
while (r-l>eps)
{
mid=(l+r)/2.0,tann=tan(mid);
memset(tr,0,sizeof(tr)),memset(sum,0,sizeof(sum));
fo(i,1,n)b[i].x=1.0*(a[i].y-a[i].x*tann),b[i].y=i;
sort(b+1,b+n+1,cmp1),tot=0;
fo(i,1,n)
{
b[i].val=++tot;
while (i<n && fabs(b[i].x-b[i+1].x)<eps)b[++i].val=tot;
}
sort(b+1,b+n+1,cmp2);ll total=0;
fd(i,n,1)total+=(sum[i]=get(1,b[i].val)),insert(b[i].val);
total+=(mid*2>pi?summ1:-summ2);
if (total>=m)r=mid;else l=mid;
}
return r;
}
int main()
{
//freopen("T2.in","r",stdin);
freopen("line.in","r",stdin);
freopen("line.out","w",stdout);
n=read(),m=n*(n-1)/2;
fo(i,1,n)a[i].x=read(),a[i].y=read();
sort(a+1,a+n+1,cmp);
fo(i,1,n)b[i].x=a[i].y,b[i].y=i;
sort(b+1,b+n+1,cmp1),tot=0;
fo(i,1,n)
{
b[i].val=++tot;
while (i<n && b[i].x==b[i+1].x)b[++i].val=tot;
}
sort(b+1,b+n+1,cmp2);
fd(i,n,1)summ1+=get(b[i].val,tot),insert(b[i].val);
memset(tr,0,sizeof(tr));
sort(a+1,a+n+1,cmp);
fo(i,1,n)b[i].x=a[i].y,b[i].y=i;
sort(b+1,b+n+1,cmp1),tot=0;
fo(i,1,n)
{
b[i].val=++tot;
while (i<n && b[i].x==b[i+1].x)b[++i].val=tot;
}
sort(b+1,b+n+1,cmp2);
fo(i,1,n)summ2+=get(b[i].val+1,tot),insert(b[i].val);
printf("%.13lf\n",m&1?binary((m+1)/2):(binary(m/2)+binary(m/2+1))/2);
return 0;
}

【JZOJ6388】小w的作业的更多相关文章

  1. XidianOJ 1076 小W喜欢的数字

    题目描述 大家都知道,小W是一名大帅哥,当然比起Light还是有点儿差距的!帅气的小W认为0-9这些数字,只有1,3,5是完美的. 欲问小W为什么,小W总是说"帅哥,是不需要解释的" ...

  2. 武汉科技大学ACM :1008: 小t和小w

    Problem Description 小t最近学了C语言,他想要在女朋友小w面前展示一下自己的能力,小w喜欢如样例所示的图形, 想让小t写一个程序来输出这样的图形,小t拿到后感觉有点困难,小t不想在 ...

  3. bzoj4665小w的喜糖 dp+容斥

    4665: 小w的喜糖 Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 120  Solved: 72[Submit][Status][Discuss] ...

  4. bzoj4665 小w的喜糖(dp+容斥)

    4665: 小w的喜糖 Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 222  Solved: 130[Submit][Status][Discuss ...

  5. bzoj2441【中山市选】小W的问题

    题目描述 有一天,小W找了一个笛卡尔坐标系,并在上面选取了N个整点.他发现通过这些整点能够画出很多个“W”出来.具体来说,对于五个不同的点(x1, y1), (x2, y2), (x3, y3), ( ...

  6. 【BZOJ 4665】 4665: 小w的喜糖 (DP+容斥)

    4665: 小w的喜糖 Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 94  Solved: 53 Description 废话不多说,反正小w要发喜 ...

  7. 【BZOJ4665】小w的喜糖 容斥+组合数

    [BZOJ4665]小w的喜糖 Description 废话不多说,反正小w要发喜糖啦!! 小w一共买了n块喜糖,发给了n个人,每个喜糖有一个种类.这时,小w突发奇想,如果这n个人相互交换手中的糖,那 ...

  8. bzoj2441 [中山市选2011]小W的问题(debug中)

    2441: [中山市选2011]小W的问题 Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 487  Solved: 186[Submit][Statu ...

  9. 小w的喜糖(candy)

    小w的喜糖(candy) 题目描述 废话不多说,反正小w要发喜糖啦!! 小w一共买了n块喜糖,发给了n个人,每个喜糖有一个种类.这时,小w突发奇想,如果这n个人相互交换手中的糖,那会有多少种方案使得每 ...

随机推荐

  1. springboot配置swagger-rest文档

    前言 swagger是一个很好的restful形式的api文档,可以通过比较小的侵入来提供很好的restful的文档.因为swagger是依赖服务生成的,所以其实是依赖服务的,这也算是它的一个小缺点吧 ...

  2. 【转】console.dir()和console.log()的区别

    原文链接:https://blog.csdn.net/ky1in93/article/details/80828499 console对象详解:https://segmentfault.com/a/1 ...

  3. 通过actionlib控制jaco机械臂

    为了安全,先写一个简单控制三个手指的程序: 根据驱动包内kinova_fingers_action.cpp服务器写客户端程序 #include <ros/ros.h> #include & ...

  4. 一个服务io占满,服务器无响应

    (1).服务器io占满,服务无响应, sar -q -f  /var/log/sa/sa28 上图显示plist-sz 增加了一倍 plist-sz 说明:进程列表中的进程(processes)和线程 ...

  5. linux 7 系统查询相关

    今天 领导让我整理一下查询关于系统信息的一些命令,查找并验证了之后,我发上来给大家分享一下. 1. #uname –a显示电脑及操作系统信息2. #cat /proc/version查看正在运行的内核 ...

  6. C# Func和匿名方法 简单使用

    今天敲代码遇见一个问题,解决中用到了C#的Func和匿名方法,发现挺好用的 定义一个这样的方法可以避免重复写try catch 这里用到了Func<int,string> ,它其实就是一个 ...

  7. nodejs 在MYSQL 数据库中插入和查询数据

    插入前的数据库: 插入后的数据库: 输出结果: demo var mysql = require('mysql'); var connection = mysql.createConnection({ ...

  8. Dubbo的初步理解和使用

    Dubbo(读音[ˈdʌbəʊ])是阿里巴巴公司开源的一个高性能优秀的服务框架,使得应用可通过高性能的 RPC 实现服务的输出和输入功能,可以和 [1]  Spring框架无缝集成. Dubbo是一款 ...

  9. 0928CSP-S模拟测试赛后总结

    依旧跌落.昨天只是偶然诈尸.我依旧是那个第二机房垫底大垃圾. 赛时打的很放松.因为T1想到了正解.对拍也打了.尽管用了大约一半的考试时间. 但是对拍拍了很久没有出错.如果你在2019年9月28日晚一下 ...

  10. bzoj1029题解

    [解题思路] 贪心,先按结束时间排序,从左到右扫描过去,如果当前建筑可以修复则入大根堆,否则,若其修复时间比堆顶小则弹出堆顶并入堆,处理完堆后则更新总时间.复杂度O(nlog2n). [参考代码] # ...