标题:钢管下料
只看楼主
爱好者初级
Rank: 1
等 级:新手上路
帖 子:4
专家分:0
注 册:2016-5-31
结帖率:0
已结贴  问题点数:20 回复次数:2 
钢管下料
每个月的生产任务是将25000mm的钢管切割成不同的长度,比如12480mm的需要4根,12400mm的需要5根,5280mm需要10根,5230需要4根,3564需要3根。每月每种生产的根数是不固定的,现在需要用C语言实现怎样下料余量最少。。。



  求大神指导
搜索更多相关主题的帖子: 任务 不同 长度 固定 C语言 
2017-08-08 22:47
Alien_Lee
Rank: 8Rank: 8
来 自:Linux帝国
等 级:蝙蝠侠
威 望:7
帖 子:149
专家分:739
注 册:2016-7-19
得分:10 
首先,你要弄清楚,总共来说,需要裁剪的长度有多少种?就以你的比如来说,总共有5种。那么将需求写入一个数组a[5],比如说第一种要5根,则a[0]=5;
如果说长度要求不固定,则采用二个数组,一个表示要求的长度,一个表示要求的数量。
然后考虑输出,从简单的角度来看的话,是输出一个二维数组c[][],每一行表示一根25000长度所要裁剪的型号的长度,比如说a[0][0]表示型号为第1根料要裁剪成型号为0的根数。
输入输出搞定了,接下来就是算法了。
总长25000是固定的,从大的开始,比如说先裁剪12480,剩下12520,如果还有12480的要求,那么如果裁剪12480,剩下40,无法裁剪任何的种类
                                                 如果裁剪12400,剩下120,无法裁剪任何种类,120》80,淘汰;
                                                 如果裁剪5280, 剩下7240,如果裁剪5280,剩下1960,无法裁剪任何种类,1960》40淘汰;
                                                                如果裁剪5230 剩下2010,无法裁剪任何种类,2010》40淘汰;
                                                                .....
对第一根找到最优的办法,然后就一直循环调用,第二根,第三根,。。
直到最后所有需求为0;
/*不帮你写代码,是不想剥夺你思考的权利*/

                                                            

  DEBUG的过程就是进步的过程,每一个小错误都是大问题!...
2017-08-09 18:13
九转星河
Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19
来 自:长长久久
等 级:贵宾
威 望:52
帖 子:5023
专家分:14003
注 册:2016-10-22
得分:10 
这个不是dfs搜索么~其实嘛~写代码思考信息量也是不少的~

[code]/*~个性签名:bug是什么意思?bug是看上去没有可能的东西实际上是有可能做到的 就是这样~2018-08-08更~*/[/code]
2017-08-09 20:06



参与讨论请移步原网站贴子:https://bbs.bccn.net/thread-479863-1-1.html




关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.308933 second(s), 8 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved