博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
CF97B:Superset——题解
阅读量:5964 次
发布时间:2019-06-19

本文共 1396 字,大约阅读时间需要 4 分钟。

题目大意:给n个点,添加一些点,使得任意两个点:

1.在同一条线上

2.以它们为顶点构成的矩形上有其他点。

输出一组可行解。

——————————————————

我发现我根本不会做英语题……看了半天题面后就去找题解了。

这是其他人的题解,但我总觉得这个人说的不明不白的(自行理解半个小时才明白的我深有感触)

首先题告诉我们随意一组解都可以,这给我们很大的自由空间,直接开始想暴力。

……但是我们不可以把点填满(题中有最大点数限制)

我们通过二分平面,对于mid点,每个在l-r中的其他的点与该点所在直线的投影就是我们需要添加的点(显然)。

同时为了防止我们添加重复的点我们需要用set维护一下。

Q1:为什么我们只需要在区间中的点的投影?

A1:我们知道在大区间内我们已经把所有的点投影到了mid,那么我们画图后发现我们对于右边的区间和左边的区间中的点一定满足上面的两种条件,故不需要加点。

Q2:为什么可行?

A2:(数都是约数)第一次我们添加了n个点,第二次我们添加了n/2*2个点,第三次我们添加了n/4*4个点……我们添加logn次,我们总共添加了nlogn个点大约1.2*10^5,总共也就大约1.3*10^5个点,一定超不了。

#include
#include
#include
#include
#include
#include
#define x first #define y second using namespace std;typedef pair
ii;inline int read(){ int X=0,w=0; char ch=0; while(!isdigit(ch)) {w|=ch=='-';ch=getchar();} while(isdigit(ch)) X=(X<<3)+(X<<1)+(ch^48),ch=getchar(); return w?-X:X;}ii p[10001];set
s;void solve(int l,int r){ if(l>=r)return; int mid=(l+r)>>1; for(int i=l;i<=r;i++){ s.insert(ii(p[mid].x,p[i].y)); } solve(l,mid); solve(mid+1,r); return;}int main(){ int n=read(); for(int i=1;i<=n;i++){ p[i].x=read(); p[i].y=read(); s.insert(p[i]); } sort(p+1,p+n+1); solve(1,n); printf("%d\n",(int)s.size()); for(set
::iterator i=s.begin();i!=s.end();i++){ printf("%d %d\n",i->x,i->y); } return 0;}

 

转载于:https://www.cnblogs.com/luyouqi233/p/8034384.html

你可能感兴趣的文章
IE维护(IEM)策略不再适用于IE10及后续IE版本
查看>>
Java7中的ForkJoin并发框架初探(下)—— ForkJoin的应用
查看>>
java中的重量级与轻量级概念
查看>>
Linux设备驱动工程师之路——硬件访问及混杂设备LED驱动
查看>>
进程和线程<一>
查看>>
远程算数程序——版本v1.0
查看>>
Mysql常见四种索引的使用
查看>>
说说Android桌面(Launcher应用)背后的故事(一)——揭开她神秘的面纱
查看>>
第一篇:zc706 开箱及开发环境搭建
查看>>
python-冒泡排序
查看>>
Mac下修改Hosts文件工具——Gas Mask
查看>>
协程函数应用
查看>>
CSU Double Shortest Paths 湖南省第十届省赛
查看>>
Tomcat学习总结(2)——Tomcat使用详解
查看>>
寒假作业二:币值转换
查看>>
webgl像机世界
查看>>
php正则怎么使用(最全最细致)
查看>>
课后作业03-验证课件上的代码,并将所有的动手动脑或要求发表博客作业部分整理成一篇博客...
查看>>
html 学习
查看>>
tomcat如何利用waf进行防护
查看>>