QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 3593|回复: 2
打印 上一主题 下一主题

[已经解决] [求助]求助

[复制链接]
字体大小: 正常 放大
chlh066        

1

主题

0

听众

52

积分

升级  49.47%

该用户从未签到

新人进步奖

跳转到指定楼层
1#
发表于 2006-5-28 00:11 |只看该作者 |倒序浏览
|招呼Ta 关注Ta

如何解决最优化分组问题

zan
转播转播0 分享淘帖0 分享分享0 收藏收藏0 支持支持0 反对反对0 微信微信

1

主题

0

听众

20

积分

升级  15.79%

该用户从未签到

新人进步奖

回复

使用道具 举报

madio        

3万

主题

1311

听众

5万

积分

  • TA的每日心情
    奋斗
    2024-7-1 22:21
  • 签到天数: 2014 天

    [LV.Master]伴坛终老

    自我介绍
    数学中国站长

    社区QQ达人 邮箱绑定达人 优秀斑竹奖 发帖功臣 风雨历程奖 新人进步奖 最具活力勋章

    群组数学建模培训课堂1

    群组数学中国美赛辅助报名

    群组Matlab讨论组

    群组2013认证赛A题讨论群组

    群组2013认证赛C题讨论群组

    现有N个小于50的数字。把他们分成若干组,每组中最多有M个数字,且每组中的数字之和不大于50。先求组数最少的分法?
    ---------------------------------------------------------------

    用贪心策略,从小到大逐个类加,和超过50就分出一组,得到的也许不是最优解,但肯定是较优解。
    ---------------------------------------------------------------

    这儿有一个更优的方法:
     void fun()
       { 
         排序:按从大到小排成一列L;
     
        while(L非空)
         {      
          将L中从头开始取数并放到一个数组A中,直到总数加上下一个数的和
          大于或等于50停止;然后又从L最后往前取数到该数组A中,直到总数
          加上下一个数的和大于或等于50停止。
          }
        }
      

    ---------------------------------------------------------------

    要实现比较优秀的算法须考虑实际状态与目标状态之间的差别最小,即让每组数的和接近50且小于50,
    各组数的和均匀.
    ---------------------------------------------------------------

    补充:还需使每组数字最多,接近M个
    数学建模社会化
    回复

    使用道具 举报

    您需要登录后才可以回帖 登录 | 注册地址

    qq
    收缩
    • 电话咨询

    • 04714969085
    fastpost

    关于我们| 联系我们| 诚征英才| 对外合作| 产品服务| QQ

    手机版|Archiver| |繁體中文 手机客户端  

    蒙公网安备 15010502000194号

    Powered by Discuz! X2.5   © 2001-2013 数学建模网-数学中国 ( 蒙ICP备14002410号-3 蒙BBS备-0002号 )     论坛法律顾问:王兆丰

    GMT+8, 2025-8-4 01:05 , Processed in 0.786519 second(s), 67 queries .

    回顶部