网站首页 > 技术文章 正文
1 | 题目
接上一篇设计了三种算法求最大公约数,本篇为上一篇的孪生姊妹篇。
本篇设计一个求最小公倍数的程序,支持三种算法,分别是枚举法、叠乘法、相除法。
2 | 设计分析
三种方法的算法说明:
枚举法:
假设两个数字#num1和#num2,比较出更大的数字赋值给变量#tempInt,变量#tempInt分别对#num1和#num2求余,如果都被整除则#tempInt为最小公倍数,否则#tempInt加1,一直循环。
叠乘法:
假设两个数字#num1和#num2,另取变量#tempInt赋初值为1,用#num1*#tempInt对#num2求余,如果整除,则#tempInt*#num1为最小公倍数,否则#temInt加1,一直循环。
相除法:
通过两个因子相互取模得到一个最大公约数,然后把两个因子的乘积除以一个最大公约数即为最小公倍数。
3 | 创建功能或功能块
添加功能块FB,命名为:“LeastCmnMultipleM3”。
4 | 定义接口变量
具体接口变量定义见下图:
注为了实现三种算法模式的切换,定义了模式变量#mode。
5 | 程序代码
编写程序代码。如下图:
本段程序中使用了与运算符“&”,意义和“AND”相同。
6 | 代码测试
在循环OB中调用FB- “LeastCmnMultipleM3”,调用时会自动创建背景数据块,命名为“InstLeastCmnMultipleM3”,该背景数据块可以用来监视和修改数据。
转至在线并监控程序。如下图:
图中模式为1,即使用枚举法算法,可以改为模式2或3,得到相同的结果。
7 | 总结
学习使用WHILE循环语句;
学习使用CASE语句;
学习设计程序时的错误处理方法,养成良好的编程习惯,为将来的项目设计打下坚实的基础。
SCL编程实例100例-010-三种方法求最小公倍数
http://bbs.plcjs.com/forum.php?mod=viewthread&tid=492978&fromuid=42656
(出处: PLC论坛-全力打造可编程控制器专业技术论坛)
猜你喜欢
- 2024-12-31 发那科机器人2DV码垛功能
- 2024-12-31 如何使用python进行正确的四舍五入?这个坑有点大
- 2024-12-31 有没有通俗易懂的动态代理示例可供参考学习?
- 2024-12-31 运算符,i.MXRT,管理工具,嵌入式,XECC技术文章分享
- 2024-12-31 第十九天:EXCEL万能字符串转换函数TEXT那些普拉斯的神操作
- 2024-12-31 自动控制原理-滞后校正设计方法以及编程实现
- 2024-12-31 C语言 | 由小到大输出两个数
- 2024-12-31 C++笔记:函数
- 2024-12-31 十万个怎么办-不清楚机器人TEST指令怎么办?
- 2024-12-31 一个 print 函数,挺会玩啊?
- 最近发表
- 标签列表
-
- cmd/c (90)
- c++中::是什么意思 (84)
- 标签用于 (71)
- 主键只能有一个吗 (77)
- c#console.writeline不显示 (95)
- pythoncase语句 (88)
- es6includes (74)
- sqlset (76)
- apt-getinstall-y (100)
- node_modules怎么生成 (87)
- chromepost (71)
- flexdirection (73)
- c++int转char (80)
- mysqlany_value (79)
- static函数和普通函数 (84)
- el-date-picker开始日期早于结束日期 (76)
- js判断是否是json字符串 (75)
- asynccallback (71)
- localstorage.removeitem (74)
- vector线程安全吗 (70)
- java (73)
- js数组插入 (83)
- mac安装java (72)
- 查看mysql是否启动 (70)
- 无效的列索引 (74)