题目大意: 每个人有两个属性.两个人之间没有冲突当且仅当一个人的两项属性都低于或另一个人的两项属性.给出N个人,从中选出最多的人,两两之间没有冲突.
思路:每个人可以映射到xy平面上的一个点,结合图形可以知道若一个固定的人,则剩下的人只能从两片区域中选出,所以可用线段树维护进行递推,但是超时.仔细观察发现,若按第一属性由低到高排序,第二属性由高到低排序,则最长上升子序列(按第二属性),则为答案.
题目大意: 每个人有两个属性.两个人之间没有冲突当且仅当一个人的两项属性都低于或另一个人的两项属性.给出N个人,从中选出最多的人,两两之间没有冲突.
思路:每个人可以映射到xy平面上的一个点,结合图形可以知道若一个固定的人,则剩下的人只能从两片区域中选出,所以可用线段树维护进行递推,但是超时.仔细观察发现,若按第一属性由低到高排序,第二属性由高到低排序,则最长上升子序列(按第二属性),则为答案.