匯程式設計序 求最大數

2021-09-21 03:18:30 字數 1482 閱讀 6048

【任務】求最大數

在buffer處給出了多個無符號數,請找出其中的最大值,放至max指定的儲存單元中。

data  segment

buffer dw 35098, 17758, 54582, 61504, 46054, 58513, 4409, 7902, 14255

dw 40623, 47645, 15575, 51572, 18110, 26511, 14880, 5921, 31999

dw 2893, 21056, 16574, 147, 25532, 33336, 5251, 64269, 31514, 23670

dw 53335, 49581, 57895, 25689, 51697, 58198, 27548, 54151, 41373

dw 44382, 23511, 39326, 56955, 51911

max dw ?

data ends

已知標號為buffer的陣列後直接就是標號為max的單元,陣列中元素的個數由程式計算,不得人工數。給定的資料中,最大者為64269(fb0dh)。

【參考解答】

assume cs:code,ds:data

data segment

buffer dw 35098, 17758, 54582, 61504, 46054, 58513, 4409, 7902, 14255

dw 40623, 47645, 15575, 51572, 18110, 26511, 14880, 5921, 31999

dw 2893, 21056, 16574, 147, 25532, 33336, 5251, 64269, 31514, 23670

dw 53335, 49581, 57895, 25689, 51697, 58198, 27548, 54151, 41373

dw 44382, 23511, 39326, 56955, 51911

max dw ?

data ends

code segment

start: mov ax, data

mov ds, ax

mov cx, offset max - offset buffer

shr cx, 1

;對字型資料,資料個數是單元數的一半

lea bx, buffer

mov ax, [bx] ;先設第乙個為最大

inc bx

inc bx

dec cx

again: cmp ax, [bx]

jae next

mov ax, [bx]

next:

inc bx

inc bx

loop again

mov max, ax

mov ax, 4c00h

int 21h

code ends

end start

匯程式設計序 求總成績

在下面的資料段中,給出了全班5名同學os al se db課程的成績,請程式設計計算出總成績,寫在0值處 datasg segment dw 54,74,71,52,0 dw 68,54,93,95,0 dw 81,52,97,67,0 dw 98,77,69,99,0 dw 79,71,69,73...

匯程式設計序 退出

作為第乙個匯程式設計序,本程式除了退出以外,並沒有執行其他的功能。目的 退出並向linux核心返回乙個狀態碼的簡單程式 輸入 無 輸出 返回乙個狀態碼.在執行程式後可通過輸入echo 來讀取狀態碼 變數 eax儲存系統呼叫號 ebx儲存返回狀態 section data section text g...

微機匯程式設計序

又是自學的一學期,呵呵。學到最後也就知道零星半點指令吧,複雜的程式可能還是不怎麼會寫,熟練當然也不敵c了,但是彙編之於嵌入式,往上走肯定少不了遇到,學好還是必要的!此次僅作入門吧。今日所學,明日之用。1 統計正負零的個數 datas segment array db 1,2,1,0,2,0,2,4,...