Консультация № 182399
06.03.2011, 15:50
54.70 руб.
0 7 1
Здравствуйте! Прошу помощи в следующем вопросе:
В массиве, состоящим из N 16-разрядных кодов, определить минимальный элемент и зафиксировать его адрес. Массив находится во внешнем ОЗУ. Процессор Intel 8051.

Обсуждение

Неизвестный
06.03.2011, 15:51
общий
Забыла дописать:оформить как подпрограмму.
Параметры подпрограммы необходимо хранить в свободной зоне резидентной памяти данных
давно
Посетитель
7438
7205
06.03.2011, 20:10
общий
Здравствуйте.
Что понимается под "свободной зоной резидентной памяти данных"?
Внутреннее ОЗУ?
Об авторе:
"Если вы заметили, что вы на стороне большинства, —
это верный признак того, что пора меняться." Марк Твен
Неизвестный
06.03.2011, 20:11
общий
Цитата: Лысков Игорь Витальевич
Здравствуйте.
Что понимается под "свободной зоной резидентной памяти данных"?
Внутреннее ОЗУ?

Да, внутреннее ОЗУ.
давно
Посетитель
7438
7205
07.03.2011, 11:36
общий
это ответ
Здравствуйте, katbka!
Можно сделать примерно так, как в предлагаемой программе
Предполагаем, что элементы хранятся в порядке "младший байт первым"
С вопросами обращайтесь в мини-форум
[code h=200]array equ 0000h ;адрес массива 16-разрядных чисел во внешней памяти
N equ 100 ;размерность массива

arr_adr_lo equ 30h ;мл байт адреса массива
arr_adr_hi equ 31h ;ст байт адреса массива
arr_count equ 32h ;длина массива
min_adr_lo equ 33h ;мл байт адреса минимального элемента
min_adr_hi equ 34h ;ст байт адреса минимального элемента
work_adr_lo equ 35h ;мл байт адреса текущего элемента
work_adr_hi equ 36h ;ст байт адреса текущего элемента
min_lo equ 37h ;мл байт минимального элемента
min_hi equ 38h ;ст байт минимального элемента

org 0 ;начало

;Зададим адрес массива и число элементов
;результат в min_adr_lo и min_adr_hi
mov arr_adr_lo, #low array ;мл байт адреса массива
mov arr_adr_hi, #high array ;ст байт адреса массива
mov arr_count, #N ;количество
call min ;ищем адрес минимального элемента

jmp $ ;зацикливаемся

min: ;поиск адреса минимального элемента
push dpl ;сохраним dptr
push dph
mov dpl, arr_adr_lo ;dptr = адресу массива
mov dph, arr_adr_hi
mov min_lo, #0ffh ;min = заведомо самому большому числу (0ffffh)
mov min_hi, #0ffh
mov r2, arr_count ;число элементов

loop: ;цикл по всем элементам
mov work_adr_lo, dpl ;сохраним адрес текущего элемента
mov work_adr_hi, dph
movx a, @dptr ;мл байт текущего элемента
mov r0, a ;сохраним
inc dptr ;на адрес ст байта
movx a, @dptr ;ст байт текущего элемента
mov r1, a ;сохраним
inc dptr ;на следующий элемент
cjne a, min_hi, cmphi ;сравним ст байт текущего элемента со ст байтом минимального
jmp cmplow ;если равны, то на сравнение мл байтов
cmphi: ;не равны
jnc next ;если текущий больше, то на следующий элемент
jmp newmin ;если меньше, то сохраняем новый минимальный

cmplow: ;сравниваем мл байты
mov a, r0 ;мл байт текущего элемента
cjne a, min_lo, cmplo ;сравним мл байт текущего элемента со мл байтом минимального
jmp next ;если равны, то на следующий
cmplo: ;не равны
jnc next ;если больше, то на следующий

newmin: ;нашли новый минимальный
mov min_adr_lo, work_adr_lo ;сохраним адрес минимального
mov min_adr_hi, work_adr_hi
mov min_lo, r0 ;и его значение
mov min_hi, r1
next: ;переходим на анализ следующего элемента
djnz r2, loop ;циклим, пока r2 не ноль
pop dph
pop dpl ;восстановим dptr
ret

end
[/code]
5
Об авторе:
"Если вы заметили, что вы на стороне большинства, —
это верный признак того, что пора меняться." Марк Твен
Неизвестный
07.03.2011, 23:12
общий
Адресаты:
Спасибо вам большое)
jmp $ ;зацикливаемся
Объясните пожалуйста вот эту строчку. Не очень понятно как зацикливаемся.
давно
Посетитель
7438
7205
08.03.2011, 11:44
общий
Да просто делается переход на начало команды jmp ($ - адрес текущей команды)
В результате будет отрабатываться только jmp, т.е. будем "крутиться" на одной команде
Об авторе:
"Если вы заметили, что вы на стороне большинства, —
это верный признак того, что пора меняться." Марк Твен
Неизвестный
08.03.2011, 16:43
общий
Адресаты:
большое спасибо)
Форма ответа