Модераторы: Poseidon
  

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> [ASM] Сортировка массива 
V
    Опции темы
Winmaster
Дата 12.5.2007, 18:51 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 15
Регистрация: 8.5.2007

Репутация: нет
Всего: нет



Программисты,помогите пожалуйста с программой на ASM в общем задача у меня такая:
На языке Ассемблер написать функции обработки массивов целых чисел: поиск минимума/максимума, сортировка по возрастанию/убыванию, определение среднего арифметического. 
СПАСИБО! 

PM MAIL   Вверх
anwe
Дата 13.5.2007, 00:37 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


Профиль
Группа: Участник
Сообщений: 748
Регистрация: 2.9.2006

Репутация: 9
Всего: 23



Для массива из слов:
Код

    .model  tiny
    .186
    .code
    org    100h
start:
    call    maxp
    call    minp
    call    sort
    call    srednee
    ret

minp    proc    near
    xor    bx,bx
    xor    cx,cx
    mov    cl,len
    shr    cx,1
    mov    ax,massiv[bx]
    mov    min,ax
    add    bx,2
l2:
    cmp    massiv[bx],ax
    jge    l1
    mov    ax,massiv[bx]
l1:
    add    bx,2
    loop    l2
    mov    min,ax
    ret
minp    endp

maxp    proc    near
    xor    bx,bx
    xor    cx,cx
    mov    cl,len
    shr    cx,1
    mov    ax,massiv[bx]
    mov    max,ax
    add    bx,2
l5:
    cmp    massiv[bx],ax
    jle    l4
    mov    ax,massiv[bx]
l4:
    add    bx,2
    loop    l5
    mov    max,ax
    ret
maxp    endp

sort    proc    near
    xor    cx,cx

    mov    i,1
l6:
    mov    cl,len
    sub    cx,2
    shr    cx,1
l7:
    mov    di,cx
    mov    si,cx
    shl    di,1
    shl    si,1
    sub    si,2
    mov    ax,massiv[si]
    mov    bx,massiv[di]
    cmp    ax,bx
    jle    l8    ;для сортировки по возрастанию
;    jbe    l8    для сортировки по убыванию
    mov    massiv[si],bx
    mov    massiv[di],ax
l8:
    dec    cx   
    mov    al,i
    cbw
    cmp    cx,ax
    jae    l7
    inc    i
    mov    al,i
    mov    bl,len
    shr    bl,1
    cmp    al,bl
    jb    l6
    ret
sort    endp

srednee    proc    near    ;с точностью до 0,5
    xor    bx,bx
    xor    ax,ax
    xor    cx,cx
    mov    cl,len
    shr    cx,1
    push    cx
l9:
    add    ax,massiv[bx]
    add    bx,2
    loop    l9
    pop    cx
    xor    dx,dx
    div    cx
    mov    sred,ax
    ret
srednee    endp

massiv    dw    5612h,345h,645h,789h,6425h,123h,4h,112h ;произвольно
len    db    $-massiv
min    dw    ?
max    dw    ?
i    db    ?
sred    dw    ?
end    start

PM MAIL   Вверх
Winmaster
Дата 13.5.2007, 01:07 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 15
Регистрация: 8.5.2007

Репутация: нет
Всего: нет



Спасибо за помощ!
 smile 

PM MAIL   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
Правила форума "Центр помощи"

ВНИМАНИЕ! Прежде чем создавать темы, или писать сообщения в данный раздел, ознакомьтесь, пожалуйста, с Правилами форума и конкретно этого раздела.
Несоблюдение правил может повлечь за собой самые строгие меры от закрытия/удаления темы до бана пользователя!


  • Название темы должно отражать её суть! (Не следует добавлять туда слова "помогите", "срочно" и т.п.)
  • При создании темы, первым делом в квадратных скобках укажите область, из которой исходит вопрос (язык, дисциплина, диплом). Пример: [C++].
  • В названии темы не нужно указывать происхождение задачи (например "школьная задача", "задача из учебника" и т.п.), не нужно указывать ее сложность ("простая задача", "легкий вопрос" и т.п.). Все это можно писать в тексте самой задачи.
  • Если Вы ошиблись при вводе названия темы, отправьте письмо любому из модераторов раздела (через личные сообщения или report).
  • Для подсветки кода пользуйтесь тегами [code][/code] (выделяйте код и нажимаете на кнопку "Код"). Не забывайте выбирать при этом соответствующий язык.
  • Помните: один топик - один вопрос!
  • В данном разделе запрещено поднимать темы, т.е. при отсутствии ответов на Ваш вопрос добавлять новые ответы к теме, тем самым поднимая тему на верх списка.
  • Если вы хотите, чтобы вашу проблему решили при помощи определенного алгоритма, то не забудьте описать его!
  • Если вопрос решён, то воспользуйтесь ссылкой "Пометить как решённый", которая находится под кнопками создания темы или специальным флажком при ответе.

Более подробно с правилами данного раздела Вы можете ознакомится в этой теме.

Если Вам помогли и атмосфера форума Вам понравилась, то заходите к нам чаще! С уважением, Poseidon, Rodman

 
1 Пользователей читают эту тему (1 Гостей и 0 Скрытых Пользователей)
0 Пользователей:
« Предыдущая тема | Центр помощи | Следующая тема »


 




[ Время генерации скрипта: 0.0690 ]   [ Использовано запросов: 21 ]   [ GZIP включён ]


Реклама на сайте     Информационное спонсорство

 
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности     Powered by Invision Power Board(R) 1.3 © 2003  IPS, Inc.