加入收藏 在线留言 联系我们
关注微信
手机扫一扫 立刻联系商家
全国服务热线18475208684

西门子PLC维修|西门子变频器代理商海南省

更新时间
2024-12-11 08:00:00
价格
请来电询价
PLC触摸屏代理商
西门子代理商
伺服电机驱动电缆
西门子一级代理商
变频器直流调速器
西门子一级总代理商
联系电话
13922889745
联系手机
18475208684
联系人
向小姐
立即询价

详细介绍

1 | 题目



把长度为n的绳子剪成m段(n>1,m>1),每段绳子的长度记为k[1]、k[2]、...、k[m],求剪切后的各段绳子的长度的Zui大乘积是多少?例如:绳子长度为8时,剪成2、3、3三段得到的乘积Zui大,值为18。



2 | 设计分析



尽可能将绳子以长度3等分为多段时,乘积Zui大。

剪切原则:

Zui优3:把绳子尽可能剪切为多个长度为3的片段,留下Zui后一段绳子的长度可能为0、1、2三种情况。

次优2:若Zui后一段绳子长度为2,则保留,不再拆分为1+1。

Zui差1:若Zui后一段绳子长度为1,则应把一份3+1替换为2+2,因为2*2>3*1。



3 | 创建功能或功能块



创建功能块FB,命名为“CutRopeGreedy”。




4 | 定义接口变量



具体接口变量定义见下图:

定义整型输入变量length,绳子的长度;

定义整型输出变量result,剪切后各段乘积的Zui大值;

定义整型静态变量statNumOf3,以长度3等分的取整段数。



5 | 程序代码



编写程序代码。如下图:


绳子长度分别为1、2、3、4时根据推论结果直接输出并返回。利用FOR循环求各段乘积,循环次数为3的段数,然后乘以剪切剩余的长度值。



6 | 代码测试



在循环OB中调用FB-“CutRopeGreedy”,调用时会自动创建背景数据块,命名为“InstCutRopeGreedy”,该背景数据块可以用来监视和修改数据。转至在线并监控程序。如下图:

输入绳子的长度8,得到各段的乘积Zui大值为18。


相关产品

联系方式

  • 电  话:13922889745
  • 经理:向小姐
  • 手  机:18475208684
  • 微  信:18475208684