999久久久精品国产消防器材,国产成人久久综合77777,√最新版天堂资源网在线,精品久久久久区二区8888,卡一卡二卡三乱码视频

技成培訓網(wǎng) 技成學習APP 技成工具箱 技成企業(yè)服務(wù)

歡迎回到技成培訓網(wǎng)

技成培訓網(wǎng)

電工題庫寶典

技成電工課堂

PLC練習題

技成PLC課堂

變頻器故障查詢

技成PLC學吧

伺服驅(qū)動故障查詢

技成PLC網(wǎng)校

當前位置:技成首頁 > 文章中心 > 新手入門 > 通過指針輕松實現(xiàn)多個數(shù)據(jù)排列

通過指針輕松實現(xiàn)多個數(shù)據(jù)排列

肖菲 發(fā)布于2024-01-11 11:17 187 6 標簽:PLC,PLC編程

PLC編程時,經(jīng)常會使用多個數(shù)據(jù),在這些數(shù)據(jù)中找到想要的數(shù)據(jù)就變得非常困難了。就像我們在茫茫人海中要尋找那個“她”,該去哪尋找?那有沒有簡單的方法去實現(xiàn)這個復雜的任務(wù)呢?那這時候,我們就要考慮使用間接尋址的方式了,也就是我們通常所說的指針。話不多說我來一個示例吧!(更多PLC課程免費試看)

t比如對下面這個序列進行從小到大排序:90 , 21 , 132 , -58 , 34

第一輪:
1) 90 和 21比,90>21,則它們互換位置:21,90,132,-58,34

2) 90 和 132 比,90<132,則不用交換位置:21,90,132,-58,34
3)132 和 –58 比,132>–58,則它們互換位置:21,90-58,132,34

4)132 和 34 比,132>34,則它們互換位置:21,90-58,34,132

到此第一輪就比較完了。第一輪的結(jié)果是找到了序列中最大的那個數(shù),并浮到了最右邊。比較時,每輪中第 n 次比較是新序列中第 n 個元素和第 n 1 個元素的比較(假如 n 從 1 開始)。

第二輪:

1) 21 和 90 比,21<90,則不用交換位置:21,90,-58,34,132
2) 90 和 –58 比,90>–58,則它們互換位置:21-58,90,34,132

3) 90 和 34 比,90>34,則它們互換位置:21,-58,34,90,132

到此第二輪就比較完了。第二輪的結(jié)果是找到了序列中第二大的那個數(shù),并浮到了最右邊第二個位置。

第三輪:

1) 21 和 –58 比,21>–58,則它們互換位置:-58,21,34,90,132

2) 21 和 34 比,21<34,則不用交換位置:-58,21,34,90,132
到此第三輪就比較完了。第三輪的結(jié)果是找到了序列中第三大的那個數(shù),并浮到了最右邊第三個位置。

第四輪:

1) –58 和 21 比,–58<21,則不用交換位置。
至此,整個序列排序完畢。從小到大的序列就是“–58 21 34 90 132”。從這個例子中還可以總結(jié)出,如果有 n 個數(shù)據(jù),那么只需要比較 n–1 輪。而且除了第一輪之外,每輪都不用全部比較。因為經(jīng)過前面輪次的比較,已經(jīng)比較過的輪次已經(jīng)找到該輪次中最大的數(shù)并浮到右邊了,所以右邊的數(shù)不用比較也知道是大的。

至此,整個順序的排列我們就做完了,這種排序方法我們稱為冒泡排序法。這種方法的原理是; 從左到右,相鄰元素進行比較。每次比較一輪,就會找到序列中最大的一個或最小的一個。這個數(shù)就會從序列的最右邊冒出來。
以從小到大排序為例,第一輪比較后,所有數(shù)中最大的那個數(shù)就會浮到最右邊;第二輪比較后,所有數(shù)中第二大的那個數(shù)就會浮到倒數(shù)第二個位置……就這樣一輪一輪地比較,最后實現(xiàn)從小到大排序。

t接下來,我們就用程序表達出這種冒泡法的思維,其中五個數(shù)據(jù)進行四輪排序,需要使用一個FOR循環(huán)語句,而每一輪的排序需要進行不同次數(shù)的比較,所以也需要使用FOR循環(huán)語句。而這兩個FOR語句是嵌套關(guān)系。

現(xiàn)在往VW0,VW2,VW4,VW6,VW85個地址中存放5個數(shù)據(jù)90 , 21 , 132 , -58 , 34,然后進行從小到大是順序排列

子程序(SBR_0


主程序(MAIN

 

當主程序M0.0接通,子程序程序解讀:

程序段1:

VW20為要循環(huán)的輪次,5個數(shù)據(jù),4輪即可

VW22則為每輪需要比較的次數(shù)

程序段2

使用外循環(huán)FOR,循環(huán)次數(shù)存儲在VW24中,循環(huán)的輪次次數(shù)為4(VW20

程序段3

創(chuàng)建指針VD100及查找第一個數(shù)據(jù)

程序段4

使用內(nèi)循環(huán)FOR,循環(huán)次數(shù)為4。

程序段5

指針VD1002存入VD104,則VD104指向VB2的起始地址。

程序段6

判斷*VD104VW2)的數(shù)據(jù)與*VD100VW0)的數(shù)據(jù),當VW2的數(shù)據(jù)小與VW0的數(shù)據(jù)則交換位置。

所以此時的數(shù)據(jù)是21 , 90 , 132 , -58 , 34。

程序段7

指針VD1002,指針指向VB2為起始的地址。

程序段9:

總的次數(shù)減1,VW22等于3

接下來,程序跳轉(zhuǎn)到程序段4,循環(huán)次數(shù)為3次,因為前兩個數(shù)據(jù)比較完了,進行后4個數(shù)據(jù)比較只需要比較3次。

程序段5中的VD100在上一個循環(huán)已經(jīng)指向了VB2開始的地址,在這個循環(huán)是加上2則VD104的數(shù)據(jù)指向VB4開始的地址。程序段6中*VD104VW4)的數(shù)據(jù)與*VD100VW2)的數(shù)據(jù)進行比較得到依次再循環(huán)。

結(jié)束語:從左到右,相鄰元素進行比較。每次比較一輪,就會找到序列中最大的一個或最小的一個。這個數(shù)就會從序列的最右邊冒出來。整個程序的邏輯是把大的數(shù)據(jù)往后挪,挪完只后即可找到相對較大的數(shù)據(jù)。

若有收獲,就點個贊吧!

文章來源于網(wǎng)絡(luò)及文獻如有侵權(quán)請聯(lián)系站長
分享到:

微信掃一掃分享

閱讀與本文標簽相同的文章

PLC PLC編程

相關(guān)推薦

最新文章 熱門文章
最新課程 免費課程
PLC資料下載 電工電氣資料下載
應用新秀
變頻器故障代碼查詢APP
伺服故障代碼查詢APP
技成
手機APP
熱門標簽