[西门子] SCL编程实例100例-003-自然数拆解

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


给定一定位数的自然数,将其每一位数字拆解出来,将结果按照从低到高的顺序存入预定义的数组中,并统计被拆解的自然数的有效位数



2 | 设计分析


采用求余算法,个位对1求余、十位对10求余、百位对100求余,以此类推。



3 | 创建功能或功能块


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




4 | 定义接口变量


具体接口变量定义见下图:
特别注意:
本例使用了局部常量“MAX_DIGITS”;
定义了一维数组,数组的上标使用了“MAX_DIGITS”,该数组用来存储拆解结果;
待拆解数据定义为“LInt”类型,是为了能够接纳更大的数据,对于“LInt”数据类型最大为19位,此处定义为18位。



5 | 程序代码


编写程序代码。如下图:


注意理解求余算法的使用。



6 | 代码测试


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





7 | 总结


学习使用FOR循环语句;
学习使用IF...ELSE语句;
学习使用乘赋值运算符“*=”(组合赋值);
学习使用一维数组;
注意指令RETURN和EXIT的用法和作用;
注意本例的程序结构,变量初始化的不同方法,特别注意使用临时变量时,一定要先赋值后使用。




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

本帖子中包含更多资源

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

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

本版积分规则