導航:首頁 > 操作系統 > 單片機中排序的方法有哪些

單片機中排序的方法有哪些

發布時間:2024-01-24 03:03:43

❶ C51單片機「冒泡法」排序實例

用keil調試下,就可以知道結果了。
感覺樓主的分析是正確的……
只是不清楚這個程序段的意圖是對數組a[]的全部數據進行排序還是僅對其前9個數據排序。
printf("the unsorted numbers:\n");
for(i=0;i<9;i++)
printf("%bx",a[i]);
printf("\n");

printf("the sorted number:\n");
for(i=0;i<=10;i++)
printf("%bx",a[i]);
按常理,這兩段應該是對應的,判斷條件下面的那個更合理,按分析前面那段只列印未排序前的a[0]~a[8];後面那段卻將11個數全部列印出來了。 (實際還應以調試結果為准)

❷ 單片機排序程序

MOV R5,#16
MOV R6,#40H
LONG:
MOV R4,#15;16個數比較15次
MOV A,30H;將30H裡面的內容復給A
MOV R0,#31H;讓其從31H開始自加到3FH
L:
SUBB A,@R0;31H裡面的內容和30H裡面的內容進行相減比較求C
JC XU;如果C=0則表示A裡面的內容大於@R0裡面的內容否則小於跳轉XU
INC R0;R0加1到下一單元地址
DJNZ R4,L;15次比較沒有結束跳轉到L繼續執行
AJMP LL;如果15次循環完畢則求出最大值,然後再循環求出次大值
XU:
MOV A,R0;放比較數的地址送A,以清零方便為第二次比較
MOV R1,A;方便清零
MOV A,@R0;最大值送A
INC R0
AJMP LL
LL:
MOV @R1,#00H;最大值地址清零,然後再比較15次求次大值
MOV R6,A;最大值送40H
INC R6
DJNZ R5,LONG;判斷是否全部從大到小排完
AJMP TT
TT:
END

❸ 單片機實驗數據排序

原發布者:瀚海湛藍
實驗一、數據排序實驗一、實驗目的熟悉8031指令系統,掌握程序設計方法。二、實驗內容編寫並調試一個排序子程序,其功能為用冒泡法將內部RAM中幾個單元位元組無符號的正整數,按從小到大的次序重新排列。三、實驗程序框圖NNN四、實驗步驟1把8032片內RAM區50H—5AH中放入不等的數據(用寄存器讀寫方法)。2用連續運行方式從起始地址0100H開始運行程序(輸入0100後按EXEC鍵)。3排序結束,顯示「P.」。4用寄存器讀寫方法檢查50—5AH中內容應從小到大排列。五、參考程序DORDE:MOVSP,#60H;設置棧指針MOVR3,#50HDORDE1:MOVA,R3MOVR0,A;數據指針傳送到R0MOVR7,#0AH;長度送到R7CLR00H;清零標志位MOVA,@R0DORDE2:INCR0MOVR2,ACLRC;清零進位標志MOV22H,@R0CJNEA,22H,DORDE3;是否相等SETBCDORDE3:MOVA,R2JCDORDE4;小於或等於不交換SETB00HXCHA,@R0DECR0XCHA,@R0;大於交換位置INCR0DORDE4:MOVA,@R0DJNZR7,DORDE2JB00H,DORDE1;未完繼續MOVR0,#7EH;完,關顯示器前三位MOVA,#0FFHMOVR4,#06HDORDE5:MOV@RO,ADECR0DJNZR4,DORDE5MOV7EH,#0CH

❹ 使用單片機匯編語言冒泡法排序

一、實驗要求
給出一組隨機數,將此組數據排序,使之成為有序數列
二、實驗目的
1.了解數據排序的簡單演算法
2.了解數列的有序和無序概念
三、實驗說明
有序的數列更有利於查找。本程序用的是「冒泡排序」法,演算法是將一個數與後面的
數相比較,如果比後面的數大,則交換,如此將所有的數比較一遍後,最大的數就會在
數列的最後面。再進行下一輪比較,找出第二大數據,直到全部數據有序。
四、程序框圖

Size equ 10 ; 數據個數
Array equ 50h ; 數據起始地址
Change equ 0 ; 交換標志

Sort:
mov r0, #Array
mov r7, #Size-1
clr Change
Goon:
mov a, @r0
mov r2, a
inc r0

mov B, @r0
cjne a, B, NotEqual
sjmp Next
NotEqual:
jc Next ; 前小後大, 不交換

setb Change ; 前大後小, 置交換標志
xch a, @r0 ; 交換
dec r0
xch a, @r0
inc r0
Next:
djnz r7, Goon
jb Change, Sort
ljmp $

end
引自:偉福單片機開發平台軟體實驗

❺ 51單片機匯編語言-請編寫程序將內部RAM 40H到4FH 中的16個數據按從小到大順序重新排列。 盡量簡單一點的

冒泡排序程序如下:

ORG 0000H
LCALL SORT ; 跳轉到排序程序
SJMP $ ; 。
SORT: ; 數據冒泡排序程序
MOV R6, #16 ;參加排序數據的總個數
DEC R6 ; 比較次數 比 數據總數 少 1

L1:
MOV R0, #40H ; 把數據的起始地址40h付給R0
MOV A, R6 ;調整比較次數
MOV R7, A
CLR F0 ; 清交換標志

L2: ;比較
MOV A, @R0 ; 取前一個數啟知
INC R0
MOV B, @R0 ; 取後一個數
CJNE A, B, L3 ; 前面的數 與 後面的數 比較, 前-後

L3: ;判斷、處理
JC N_JH ; 後面的伏薯數 大於 前面的數,不交換
XCH A,B ; 否則前後兩數交換存放
MOV @R0,缺旁者A
DEC R0
MOV @R0,B
INC R0
SETB F0 ; 設交換標志

N_JH:
DJNZ R7, L2 ; 沒有比較完,就繼續
JNB F0, L_END ; 沒有交換過,就結束
DJNZ R6, L1

L_END:
RET ; 排序完成。

;結果是:
;40H中存放著最小的數;
;4FH中存放著最大的數。

❻ 51單片機匯編 排序問題 請各位賜教

單片機排序問題,可以參考:
http://..com/question/148407042.html
試設計一個子程序,其功能為將(RO)指出的內部RAM中6個單位元組正整數按從小到大的次序重新排列。

模擬測試通過.

ORG 0000H

MOV 40H, #8AH
MOV 41H, #3BH
MOV 42H, #0B9H
MOV 43H, #47H
MOV 44H, #29H
MOV 45H, #0AFH

CALL SORT6 ;調用排序子程序
NOP
NOP
SJMP $
;-------------------------------------
SORT6: ;排序子程序
MOV R6, #5
S1:
MOV B, R6
MOV R7, B
MOV R0, #40H ;起始地址
S2:
MOV B, @R0
INC R0
MOV A, @R0
CJNE A, B, S3
S3:
JNC N_JH
MOV @R0, B
DEC R0
MOV @R0, A
INC R0
N_JH:
DJNZ R7, S2
DJNZ R6, S1
RET
;-------------------------------------
END

三位元組的加法,在我的空間,也有。
http://hi..com/%D7%F6%B6%F8%C2%DB%B5%C0

❼ 有誰懂單片機的冒泡法排序嗎

懂的人很多的...
就和C語言的是一個道理..
冒泡排序是很費時的...每一次只冒一個..
雖說可能用不了,N-1次,但在某些組合的情況下是會用到那麼多次..
這也是為了完全排出大小...

❽ 單片機io口怎麼排序呢

這里的PIO口都是個一位元組的寄存器,晶元內部規定P2.0為最低位,P2.7為最高位;
而數據的表示方式按約定是高位在左低位在右的排序,所以有你看到的1111 1110的順序;
而當數據按位進行串列傳輸,同時先傳低位時,就有你想看到的0111 1111 的順序了;

❾ 編寫簡單的單片機c語言程序 1、指定數組找最大值 2、排序

#include<stdio.h>

#defineNR10//數組元素個數

/*從主函數開始*/

intmain(intargc,char**argv)

{

intar[NR];

inti;

fprintf(stdout,"請輸入%d個整數: ",NR);

/*獲取並檢查用戶輸入*/

while(1)

{

/*循環獲取NR個數據*/

for(i=0;i<NR;i++)

{

if(fscanf(stdin,"%d",&ar[i])!=1)

{

fprintf(stdout,"輸入錯誤!請重新輸入: ");

while(getchar()!=' ');//丟棄多餘非法字元

break;//打破內層for循環

}

}

/*檢查是否獲取到NR個數據*/

if(i!=NR)

{

continue;

}

else

{

break;

}

}

/*查找最大值和最小值*/

intmax,min;

max=ar[0];//假定第一個數為最大值

min=ar[0];//同時假定也第一個數為最大值

/*從第二個數開始比較查找最值*/

for(i=1;i<NR;i++)

{

if(ar[i]>max)//最大值

{

max=ar[i];

}

if(ar[i]<min)//最小值,不能使用elseif,否則會跳過比較

{

min=ar[i];

}

}

fprintf(stdout,"最大值為:%d最小值為:%d ",max,min);

/*接下來:查找第二大值*/

intsecond;

/*先獲取前兩個數的第一大和第二大值*/

ar[0]>ar[1]?(max=ar[0],second=ar[1]):

(max=ar[1],second=ar[0]);

/*從第2個數開始比較查找*/

for(i=2;i<NR;i++)

{

if(ar[i]>max)//查找最大值:目的是為了比較第二大值

{

second=max;//先把最大值保存給第二大值

max=ar[i];

}

elseif(second<ar[i])//比最大值小的數再看看是否大於第二大值

{

second=ar[i];

}

}

fprintf(stdout,"第二大值為:%d ",second);

return0;

}

(9)單片機中排序的方法有哪些擴展閱讀

一、c語言程序求數組內所有數的和:

1、通過索引的方式就可以訪問到數組內部的元素,索引是從0到數組長度-1。

2、數組點Lenth就是數組的長度。

二、c語言程序冒泡排序:

1、比較相鄰的兩個元素的大小,如果第一個比第二個大就互換一下。

2、然後每一對都做如上操作,如此一來最後一個元素肯定是最大的數了。

3、除了最後一個元素,重復以上步驟。然後倒數第二個就是次大的值了

4、一次按照這個邏輯直到沒有任何數字可以比較了。

閱讀全文

與單片機中排序的方法有哪些相關的資料

熱點內容
怎麼關閉手機通訊錄對外app 瀏覽:370
我的世界如何強行進入一個滿人的伺服器 瀏覽:653
什麼app可以查詢會考成績 瀏覽:389
程序員能創造的價值 瀏覽:259
伺服器上的redis是什麼意思 瀏覽:379
軟體產品經理與程序員 瀏覽:922
高中生程序員 瀏覽:892
ps處理pdf 瀏覽:723
伺服器c1什麼意思 瀏覽:222
哈爾濱手機什麼app拍違章有獎勵 瀏覽:477
盜賊用什麼app最好 瀏覽:902
51單片機如何測量電導率 瀏覽:499
移動花卡怎麼使用app流量 瀏覽:554
個稅演算法2021表格公式解讀 瀏覽:174
怎麼進入電腦板2b2t伺服器 瀏覽:284
idea編譯進度條 瀏覽:134
文件夾工具箱軟體 瀏覽:688
最近為什麼手機連不上索尼伺服器 瀏覽:877
海康錄像機怎麼關視頻加密 瀏覽:788
編程以後有可能被機器人代替嗎 瀏覽:524