计算几何 LIS
洛谷题目传送门
BZOJ3663
BZOJ4660
BZOJ4206
这套题老师拿给我们考简直有毒
神题根本不会做,考场上就写了个10分代码。
我们通过看题解画图可以发现,当两个点的切点所对应的弧相交且不包含时才能满足题意。
差不多长这样:
和[HAOI2008]下落的圆盘这道题一个套路,我们把圆上的点对应到区间上来。
原问题转化为:找到最多的线段数,使得它们两两相交但不包含。
我们先对这些线段以左端点为第一关键字,右端点为第二关键字排个序。然后枚举每一个线段,把左端点在该线段内的线段拿出来,对右端点跑LIS就好了。复杂度 O(