[西门子] SCL编程实例100例-007-自然数反转

[复制链接]
查看64 | 回复0 | 2024-4-24 20:39:53 | 显示全部楼层 |阅读模式
1 | 题目


将一定数位的自然数的每一位数字拆解后,按照反序进行排列形成一个新的自然数。例如:给定自然数为15928671860,反转后得到新的自然数6817682951。



2 | 设计分析


首先将给定的自然数按位进行拆解并求出有效位数,将拆解后的最高位数字作为新自然数的个位,其它依次乘以10倍、100倍、1000倍,分别放到十位、百位、千位……,以此类推。



3 | 创建功能或功能块


添加功能块FB,命名为:“InverseNumber”。




4 | 定义接口变量


具体接口变量定义见下图:
注意定义了用来拆解自然数的多重实例,即调用自然数拆解功能块(子程序)。



5 | 程序代码


编写程序代码。如下图:


注意自然数拆解子程序的调用和实参的传递方式,对于子程序的输出结果此处并未定义形参进行传递,而是直接引用了背景数据块里的值,不利于程序的封装,所以不提倡该方式。



6 | 代码测试


在循环OB中调用FB- “InverseNumber”,调用时会自动创建背景数据块,命名为“InstInverseNumber”,该背景数据块可以用来监视和修改数据。
转至在线并监控程序。如下图:
给定自然数15928671860,反转后结果为6817682951,因要求反转后仍为自然数,故高位0被忽略。



7 | 总结


学习使用FOR循环语句;
学习子程序的调用和实参的传递;
学习使用一维数组。



免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!

本帖子中包含更多资源

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

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

本版积分规则