比如在100个字里存有100个数据,如何快速找到最大值?西门子库里有没有?
谢谢!
最佳答案
只能利用指针编写程序,来找出最大值。
转:
冒泡排序
假定100个数据,放在DB1中,安放顺序如下:
DBD0
DBD4
…
DBD396
下面是西门子的程序
OPN DB 1 /////打开DB1这个数据块
L 100 ////装载10到MB0中,因为有100个数据,要进行100次排序,99次也可以的
LL0: T MB 0
L P#0.0 ////装载地址指针,这是关键,不要搞错了
LAR1
L 99
LL1: T MB 2 ////内部循环,进行99次,直到把最大值排到最后
L DBD [AR1,P#0.0]
L DBD [AR1,P#4.0]
<R
JC LL2 ////比较前后两个值,如果前面大于后面的,则前后数据交换
L DBD [AR1,P#0.0]
T MD10
L DBD [AR1,P#4.0]
T DBD [AR1,P#0.0]
L MD10
T DBD [AR1,P#4.0]
LL2: +AR1 P#4.0 ////指针自动进行加4,因为是浮点数,所以要跳过4个字节
L MB 2
LOOP LL1 ///这个指令自动的将A寄存器里的值减1
L MB 0
LOOP LL0
提问者对于答案的评价:
程序没看懂,但是知道怎么做了。
用循环语句,每个循环比较大小,指针每循环加一个字长或双字长度。
谢谢!
原创文章,作者:more0621,如若转载,请注明出处:https://www.zhaoplc.com/plc242565.html