qq_29333729 2019-06-24 10:43 采纳率: 0%
浏览 475
已结题

查找满足多个互斥条件的分组方法

问题:有n个元素a、b、c、d、e、f...,要求将这些元素拆分成m个分组,同时满足条件:集合{a,b,c,d},{b,d,f},{c,e}....内的元素不能在同一个分组。

默认n和m满足分组条件,1个元素可以出现在多个条件集合内;结果不唯一,只要给出1个较优结果,即各个分组内元素数量较均匀。

我的能想到的方法是,先整理出每个元素与其他元素的互斥关系,比如a不能与{b,c,d}在同1分组,b不能与{a,c,d,f}在同1分组...,然后将每个元素互斥条件最多的,从多到少随机分配在m个分组内,每次随机验证是否满足条件,全部随机完成返回结果。

但是这个方法比较暴力,而且不能给出最优解,计算开销也比较大。

求算法大神给个思路或意见。

  • 写回答

1条回答 默认 最新

  • bighero4 2019-06-24 15:33
    关注

    如果是计算最小要分成几组,可以使用拓扑排序,这里分成指定的组数,需要改进下。建议去看看NOIP2013普及复试中的第4题车站分级的问题,或许那里的解题思想可以借用。

    评论

报告相同问题?

悬赏问题

  • ¥15 #MATLAB仿真#车辆换道路径规划
  • ¥15 java 操作 elasticsearch 8.1 实现 索引的重建
  • ¥15 数据可视化Python
  • ¥15 要给毕业设计添加扫码登录的功能!!有偿
  • ¥15 kafka 分区副本增加会导致消息丢失或者不可用吗?
  • ¥15 微信公众号自制会员卡没有收款渠道啊
  • ¥100 Jenkins自动化部署—悬赏100元
  • ¥15 关于#python#的问题:求帮写python代码
  • ¥20 MATLAB画图图形出现上下震荡的线条
  • ¥15 关于#windows#的问题:怎么用WIN 11系统的电脑 克隆WIN NT3.51-4.0系统的硬盘