Отправляет email-рассылки с помощью сервиса Sendsay
  Все выпуски  

RFpro.ru: Ассемблер? Это просто! Учимся программировать


РАССЫЛКИ ПОРТАЛА RFPRO.RU

Лучшие эксперты в разделе

Evgen aka Chuma
Статус: 6-й класс
Рейтинг: 14
∙ повысить рейтинг »
Kdsfofwe21
Статус: 1-й класс
Рейтинг: 0
∙ повысить рейтинг »
Коцюрбенко Алексей aka Жерар
Статус: Мастер-Эксперт
Рейтинг: 0
∙ повысить рейтинг »

∙ Assembler

Номер выпуска:1717
Дата выхода:05.12.2018, 00:15
Администратор рассылки:Лысков Игорь Витальевич (Старший модератор)
Подписчиков / экспертов:66 / 21
Вопросов / ответов:1 / 1

Консультация # 194032: Уважаемые эксперты! Прошу вас помочь с составлением программы для CompModel. Сортировка массива от минимального значения к максимальному. Заранее - большое спасибо! ...

Консультация # 194032:

Уважаемые эксперты! Прошу вас помочь с составлением программы для CompModel. Сортировка массива от минимального значения к максимальному.
Заранее - большое спасибо!

Дата отправки: 30.11.2018, 00:14
Вопрос задал: soloveujenya (Посетитель)
Всего ответов: 1
Страница онлайн-консультации »


Консультирует Лысков Игорь Витальевич (Старший модератор):

Здравствуйте, soloveujenya!
Держите программку.
Данные в количестве 10 штук необходимо записать, начиная с адреса 40
Используется пузырьковая сортировка в два цикла.

Код (Assembler) :: выделить код
RD #40 ;адрес начала массива
WR R0 ;адресацию во внешнем цикле сортировки будем делать с помощью регистра R0
RD #50 ;адрес ЗА массивом, т.е. в массиве 10 элементов (чтобы работала команда JS)
WR R3 ;в регистре R3, для внутреннего цикла сортировки

SBI #1 ;внешний цикл сортировки до предпоследнего элемента
WR R2 ;в регистре R2
      ;внешний цикл сортировки
L1:RD R0 ;начальный адрес внутреннего цикла на 1 больше внешнего 
ADI #1
WR R1 ;адрес внутреннего цикла
      ;внутренний цикл сортировки
L2:RD @R1 ;сравниваем текущий элемент внутреннего цикла
SUB @R0 ;с текущим внешнего
JNS NEXT2 ;если больше или равно, то на следующий элемент внутреннего цикла

RD @R1 ;если меньше, то меняем местами текущий элемент внутреннего цикла
WR R4
RD @R0 ;и внешнего
WR @R1
RD R4
WR @R0

NEXT2: ;на следующий элемент внутреннего цикла
RD R1 ;инкремент адреса
ADI #1
WR R1
SUB R3 ;сравниваем, дошли ли до конца массива
JS L2 ;нет - продолжаем

RD R0 ;на следующий элемент внешнего цикла
ADI #1
WR R0
SUB R2 ;сравниваем, дошли ли до предпоследнего элемента массива
JS L1 ;нет - идем на следующий внутренний цикл

HLT ;задача выполнена. По адресу, начиная с 40 - отсортированный массив

Консультировал: Лысков Игорь Витальевич (Старший модератор)
Дата отправки: 01.12.2018, 14:25

5
нет комментария
-----
Дата оценки: 02.12.2018, 01:19

Рейтинг ответа:

НЕ одобряю +1 одобряю!


Оценить выпуск | Задать вопрос экспертам

главная страница  |  стать участником  |  получить консультацию
техническая поддержка

Дорогой читатель!
Команда портала RFPRO.RU благодарит Вас за то, что Вы пользуетесь нашими услугами. Вы только что прочли очередной выпуск рассылки. Мы старались. Пожалуйста, оцените его. Если совет помог Вам, если Вам понравился ответ, Вы можете поблагодарить автора - для этого в каждом ответе есть специальные ссылки. Вы можете оставить отзыв о работе портале. Нам очень важно знать Ваше мнение. Вы можете поближе познакомиться с жизнью портала, посетив наш форум, почитав журнал, который издают наши эксперты. Если у Вас есть желание помочь людям, поделиться своими знаниями, Вы можете зарегистрироваться экспертом. Заходите - у нас интересно!
МЫ РАБОТАЕМ ДЛЯ ВАС!


В избранное