|
創(chuàng)建指針時,必須使用“移動雙字”指令,將間接尋址的存儲單元地址移至指針位置。;用“&”符號加上要訪問的存儲區(qū)地址可建立一個指針,當(dāng)指令中的操作數(shù)是指針時,應(yīng)該在操作數(shù)前加上“*”號。 1.建立指針
建立指針記得加“&”;將VB100的地址存放到VD1000內(nèi)。
按字節(jié)尋址,就+1; 按字尋址,就+2; 按雙字或浮點數(shù)尋址,就+4;
子程序
程序的監(jiān)控圖就不貼出來了,其實重點就在子程序的第二段,每循環(huán)一次,就做一次比較,如果比較條件滿足,就將大值和小值暫存到LD10和LD14中,直到循環(huán)到最后一次,此時最大值和最小值已經(jīng)找出來了,平均值就是將每循環(huán)一次的值進(jìn)行累加,然后再除以數(shù)據(jù)個數(shù),這里我就不展開仔細(xì)的分析了,可以參考一下最后一個案例,冒泡排序執(zhí)行原理。
案例4,冒泡排序,從小排到大。 主程序,排8組數(shù)據(jù)。
子程序
冒泡排序算法解析: 八組數(shù)據(jù):分別是20.0;365.0;7.0;7.0;210.5;7.6;15.6;22.8。 1.首先將要排列的數(shù)據(jù)個數(shù)-2(8-2),然后存放到LW10中;再將這個值附給外循環(huán)的FINAL。 2.第一個外循環(huán)的執(zhí)行的次數(shù)即為0~6(7次)。 3.INDX:假定 INIT 值為 0,F(xiàn)INAL 值為 6,則 FOR 指令和 NEXT 指令之間的指令將執(zhí)行 7 次,INDX 值遞增:0,1, 2, 3, 4.5.6。 第一次外循環(huán)(執(zhí)行7次內(nèi)循環(huán)) 第一次內(nèi)循環(huán) 20.0;365.0;7.0;7.0;210.5;7.6;15.6;22.8;(20.0<365.0,位置不變) 第二次內(nèi)循環(huán) 20.0;7.0;365.0;7.0;210.5;7.6;15.6;22.8;(7.0<365.0,位置改變) 第三次內(nèi)循環(huán) 20.0;7.0;7.0;365.0;210.5;7.6;15.6;22.8;(7.0<365.0,位置改變) 第四次內(nèi)循環(huán) 20.0;7.0;7.0;210.5;365.0;7.6;15.6;22.8;(210.5<365.0,位置改變) 第五次內(nèi)循環(huán) 20.0;7.0;7.0;210.5;7.6;365.0;15.6;22.8;(7.6<365.0,位置改變) 第六次內(nèi)循環(huán) 20.0;7.0;7.0;210.5;7.6;15.6;365.0;22.8;(15.6<365.0位置改變) 第七次內(nèi)循環(huán) 20.0;7.0;7.0;210.5;7.6;15.6;22.8;365.0;(22.8<365.0位置改變,找到最大值),即最大值365.0。 第二次外循環(huán)(執(zhí)行6次內(nèi)循環(huán)) 第一次內(nèi)循環(huán) 7.0;20.0;7.0;210.5;7.6;15.6;22.8;365.0;(7.0<20.0,位置改變) 第二次內(nèi)循環(huán) 7.0;7.0;20.0;210.5;7.6;15.6;22.8;365.0;(7.0<20.0,位置改變) 第三次內(nèi)循環(huán) 7.0;7.0;20.0;210.5;7.6;15.6;22.8;365.0;(20.0<210.5,位置不變,接下來就是210.5跟后面的數(shù)進(jìn)行比較) 第四次內(nèi)循環(huán) 7.0;7.0;20.0;7.6;210.5;15.6;22.8;365.0;(7.6<210.5,位置改變) 第五次內(nèi)循環(huán) 7.0;7.0;20.0;7.6;15.6;210.5;22.8;365.0;(15.6<210.5,位置改變) 第六次內(nèi)循環(huán) 7.0;7.0;20.0;7.6;15.6;22.8;210.5;365.0;(22.8<210.5,位置改變,找到第二個值),即第二大值210.5。 第三次外循環(huán)(執(zhí)行5次內(nèi)循環(huán)) 第一次內(nèi)循環(huán) 7.0;7.0;20.0;7.6;15.6;22.8;210.5;365.0;(7.0=7.0,這里的排序就不變,假設(shè)第一個值為8.0,8.0>7.0,則位置改變) 第二次內(nèi)循環(huán) 7.0;7.0;20.0;7.6;15.6;22.8;210.5;365.0;(7.0<20.0,位置改變) 第三次內(nèi)循環(huán) 7.0;7.0;7.6;20.0;15.6;22.8;210.5;365.0;(7.6<20.0,位置改變) 第四次內(nèi)循環(huán) 7.0;7.0;7.6;15.6;20.0;22.8;210.5;365.0;(15.6<20.0,位置改變) 第五次內(nèi)循環(huán) 7.0;7.0;7.6;15.6;20.0;22.8;210.5;365.0;(20.0<22.8,位置不變,找出第三個值),即第三大值22.8。 第四次外循環(huán)(執(zhí)行4次內(nèi)循環(huán)) 第一次內(nèi)循環(huán) 7.0;7.0;7.6;15.6;20.0;22.8;210.5;365.0;(7.0=7.0,位置不變) 第二次內(nèi)循環(huán) 7.0;7.0;7.6;15.6;20.0;22.8;210.5;365.0;(7.0<7.6,位置不變) 第三次內(nèi)循環(huán) 7.0;7.0;7.6;15.6;20.0;22.8;210.5;365.0;(7.6<15.6,位置不變) 第四次內(nèi)循環(huán) 7.0;7.0;7.6;15.6;20.0;22.8;210.5;365.0;(15.6<20.0,位置不變,找出第四個值),即最第四大值20.0。 第五次外循環(huán)(執(zhí)行3次內(nèi)循環(huán)) 第一次內(nèi)循環(huán) 7.0;7.0;7.6;15.6;20.0;22.8;210.5;365.0;(7.0=7.0,位置不變) 第二次內(nèi)循環(huán) 7.0;7.0;7.6;15.6;20.0;22.8;210.5;365.0;(7.0<7.6,位置不變) 第三次內(nèi)循環(huán) 7.0;7.0;7.6;15.6;20.0;22.8;210.5;365.0;(7.6<15.6,位置不變,此時找出第五個值),即第五大值15.6。 第六次外循環(huán)(執(zhí)行2次內(nèi)循環(huán)) 第一次內(nèi)循環(huán) 7.0;7.0;7.6;15.6;20.0;22.8;210.5;365.0;(7.0=7.0,位置不變) 第二次內(nèi)循環(huán) 7.0;7.0;7.6;15.6;20.0;22.8;210.5;365.0;(7.0<7.6,位置不變,此時找出第六個值),即第六大值7.6。 第七次外循環(huán)(執(zhí)行1次內(nèi)循環(huán)) 第一次內(nèi)循環(huán) 7.0;7.0;7.6;15.6;20.0;22.8;210.5;365.0;(7.0=7.0,位置不變,此時找出第七個值),即第七大值7.0。 那么最后的那個數(shù)顯然就是最小值了。 最后由小到大依次排列出來的結(jié)果(7.0;7.0;7.6;15.6;20.0;22.8;210.5;365.0)。 其實這是一種冒泡排序法,熟悉計算機(jī)語言的小伙伴就應(yīng)該比較了解這種算法,至于冒泡算法的具體原理和說明,請各位小伙伴自行百度一下,這里就不再贅述了。 程序執(zhí)行原理: 第一次外循環(huán) 第一次內(nèi)循環(huán) LW8=0,AC1=0*4,AC2=0+4,AC0=0,AC2=4;LD0偏移0和4,即VD1000和VD1004做比較(>),由于VD1000=20.0不大于VD1004=365.0;則程序6不執(zhí)行,排序不改變(即20.0;365.0;7.0;7.0;210.5;7.6;15.6;22.8;)。 第二次內(nèi)循環(huán) LW8=1,AC1=1*4,AC2=4+4,AC0=4,AC2=8;LD0偏移4和8,即VD1004和VD1008做比較(>),由于VD1004=365.0>VD1008=7.0; 則程序6執(zhí)行,*AC1(VD1004=365.0)的值存放到TEMP里(TEMP=365.0),然后*AC2(VD1008=7.0)把值傳給*AC1(VD1004=7.0),最后將TEMP的值傳給*AC2(VD1008),此時VD1004=7.0,VD1008=365.0,排序發(fā)生變化(即20.0;7.0;365.0;7.0;210.5;7.6;15.6;22.8;)。 第三次內(nèi)循環(huán) LW8=2,AC1=2*4,AC2=8+4,AC0=8,AC2=12;LD0偏移8和12,即VD1008和VD1012做比較(>),由于VD1008=365.0>VD1012=7.0,則程序6執(zhí)行,*AC1(VD1008=365.0)的值存放到TEMP里(TEMP=365.0),然后*AC2(VD1012=7.0)把值傳給*AC1(VD1008=7.0),最后將TEMP的值傳給*AC2(VD1012),此時VD1008=7.0,VD1012=365.0,排序發(fā)生變化(即20.0;7.0;7.0;365.0;210.5;7.6;15.6;22.8;)。 第四次內(nèi)循環(huán) LW8=3,AC1=3*4,AC2=12+4,AC0=12,AC2=16;LD0偏移12和16,即VD1012和VD1016做比較(>),由于VD1012=365.0>VD1016=210.5, 則程序6執(zhí)行,*AC1(VD1012=365.0)的值存放到TEMP里(TEMP=365.0),然后*AC2(VD1016=210.5)把值傳給*AC1(VD1012=210.5),最后將TEMP的值傳給*AC2(VD1016),此時VD1012=210.5,VD1016=365.0,排序發(fā)生變化(即20.0;7.0;7.0;210.5;365.0;7.6;15.6;22.8;)。 第五次內(nèi)循環(huán) LW8=4,AC1=4*4,AC2=16+4,AC0=16,AC2=20;LD0偏移16和20,即VD1016和VD1020做比較(>),由于VD1016=365.0>VD1020=7.6, 則程序6執(zhí)行,*AC1(VD1016=365.0)的值存放到TEMP里(TEMP=365.0),然后*AC2(VD1020=7.6)把值傳給*AC1(VD1016=7.6),最后將TEMP的值傳給*AC2(VD1020),此時VD1016=7.6,VD1020=365.0,排序發(fā)生變化(即20.0;7.0;7.0;210.5;7.6;365.0;15.6;22.8;)。 第六次內(nèi)循環(huán) LW8=5,AC1=5*4,AC2=20+4,AC0=20,AC2=24;LD0偏移20和24,即VD1020和VD1024做比較(>),由于VD1020=365.0>VD1024=15.6, 則程序6執(zhí)行,*AC1(VD1020=365.0)的值存放到TEMP里(TEMP=365.0),然后*AC2(VD1024=15.6)把值傳給*AC1(VD1020=15.6),最后將TEMP的值傳給*AC2(VD1024),此時VD1020=15.6,VD1024=365.0,排序發(fā)生變化(即20.0;7.0;7.0;210.5;7.6;15.6;365.0;22.8;)。 第七次內(nèi)循環(huán) LW8=6,AC1=6*4,AC2=24+4,AC0=24,AC2=28;LD0偏移24和28,即VD1024和VD1028做比較(>),由于VD1024=365.0>VD1028=22.8, 則程序6執(zhí)行,*AC1(VD1024=365.0)的值存放到TEMP里(TEMP=365.0),然后*AC2(VD1028=22.8)把值傳給*AC1(VD1024=22.8),最后將TEMP的值傳給*AC2(VD1028),此時VD1024=22.8,VD1028=365.0,排序發(fā)生變化(即20.0;7.0;7.0;210.5;7.6;15.6;22.8;365.0;)。最后找到了最大值,此時VD1028=365.0。 下面的循環(huán)就不在贅述,原理同上。
|
|
|