无法直接构造最大流来解决这个问题,因为题目要求每首舞曲都需要n对男女进行跳舞. 答案又满足单调性,这启发我们二分答案,判断是否满流验证答案. 假设舞曲数目为x时满足条件,那么每个男生和女生都需要跳x次舞. 连边(s,男i,x), (女i,t,x)来进行限制. 同时要求每个男生最多可以和k个不喜欢的女生跳舞,女生同样.那么把男生和女生拆成两个点,分别表示和喜欢的人跳舞,和不喜欢的人跳舞. 那么连边(男i,男i',k),(女i',女i,k)来进行限制. 同样的一对男女只准跳一次.那么将边容量设为1即…