[西门子] SCL编程实例100例-028-一个三位数的问题

[复制链接]
查看87 | 回复0 | 2024-12-11 08:09:31 | 显示全部楼层 |阅读模式
>

1 | 题目



用1-9九个数字组成三个三位数,要求第二个数、第三个数分别是第一个数的2倍和3倍,只使用这九个数字组成三个三位数,不能重复使用数字,编写程序计算满足以上要求一共有几组结果。



2 | 设计分析



只要确定第一个三位数就可以解决问题,试探第一个三位数后,计算出另外两个数,将其分解成三个数字,判断这三个三位数中是否有重复数字。注意:满足以上要求试探的初始值是123,最大值是333。



3 | 创建功能或功能块



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




4 | 定义接口变量



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

预定义6*3的二维数组#resultQs用来保存结果,变量#countQ记录结果组数。



5 | 程序代码



编写程序代码。如下图:


由于不知道有多少组结果,所以有可能超过预定义数组的限值,此处需要增加条件判断,否则会运行出错。程序中判断重复数字调用了前篇编写的子程序,注意数据类型的强制转换(数据类型INT的数据长度不够)。



6 | 代码测试



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

一共得到5组结果:192、384、576;219、438、657;267、534、801;273、546、819;327、654、981。



7 | 总结



学习使用FOR循环语句;

学习使用IF..ELSE语句;

学习使用二维数组;

学习数据类型的强制转换;

学习RETURN语句的作用。

-

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有账号?注册哦

x
您需要登录后才可以回帖 登录 | 注册哦

本版积分规则