Форум программистов, компьютерный форум, киберфорум
Assembler: DOS/Real Mode/16-bits
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.56/18: Рейтинг темы: голосов - 18, средняя оценка - 4.56
0 / 0 / 0
Регистрация: 19.03.2012
Сообщений: 20

Циклический сдвиг массива

04.02.2013, 18:09. Показов 3437. Ответов 7
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Написать подпрограмму, циклически сдвигающую массив на 5 бит влево. Адрес массива задан парой FS:BX, длина (в байтах) - регистром CX. При выполнении использовать комманду двойного сдвига.

Комманда двойного сдвига, насколько я понял shld.

Но главный вопрос как сдвигать используя адрес массива из FS:BX.

Вот код, который я написал:
Assembler
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
sseg segment stack 'stack'use16
     dw 256 dup(?)
sseg ends
 
.386
 
data segment use16
array   db 1,3,4,5,3,4
data ends
 
Cseg    segment use16
        assume  cs:Cseg,ds:data
start:  
    mov ax,data
    mov ds,ax
    mov fs,ax
    
    mov bx,offset array
    mov cx,6        ; длина
 
    call print_mas
    call Sdvig 
    call print_mas
 
    mov    ah,4ch      
    int    21h
    
Sdvig proc
    push ax cx              ; сохранить AX
        
    [COLOR="Red"];shld array,fs:[bx],5 <- в этом месте ошибка Как правильно вызвать эту операцию?[/COLOR]
    
    pop cx  ax          ; восстановить AX
    ret             ; вернуться в вызывающую программу
Sdvig endp
 
print_mas proc ; вывод массива
    push ax             ; сохранить AX
    mov si,0            ;индекс начального элемента в cx
    mov cx,6
go:             ;цикл инициализации
    mov al,array[si]
    add al,30h 
    mov dl,al
    mov ah,2h 
    int 21h 
    
    mov ah,2h 
    mov dl,' '
    int 21h  
    
    inc si      ;продвижение к следующему элементу массива
    loop    go  ;повторить цикл
                    ; помощью функции DOS
    pop ax              ; восстановить AX
    ret      ; вернуться в вызывающую программу
print_mas endp
 
Cseg    ends
end    start
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
04.02.2013, 18:09
Ответы с готовыми решениями:

Циклический сдвиг masm32
Как с помощью циклического сдвига из 3333h получить 2222h? Ведь 3333h = 11001100110011, а 2222h = 10001000100010, они сдвигом просто не...

Циклический сдвиг массива
Ув. программисты! нужна помощь. в следующем коде нужно создать рандомный массив А от 1 до 10 и выполнить циклический свиг на k позиций...

Циклический сдвиг массива
Напишите программу, которая вводит с клавиатуры непустой массив целых чисел, циклический сдвигает элементы массива вправо на к позиции, и...

7
539 / 399 / 99
Регистрация: 18.08.2012
Сообщений: 1,024
05.02.2013, 10:09
Тут нужно не запутаться в понимании, что и куда сдвигается. Если считать, что при сдвиге массива (AB) влево "старшие байты надвигаются на младшие", то
Assembler
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
    xor    ebx,ebx
    push   ds
    pup    fs
    mov    ecx,17 ; размер массива AB в байтах
    shr    ecx,5    ; сдвигаем словами на 5 битов
    pushf            ; сохраним флаги
  loop0:
    mov    ax,Word Ptr fs:AB[ebx]
    mov    dx,Word Ptr fs:AB[ebx+2]
    shrd   ax,dx,5
    mov    Word Ptr fs:AB[ebx],ax
    inc    ebx       ; чтобы не испортить флаги
    inc    ebx
    loop   loop0
    popf
    jnc    M
    shr    byte Ptr fs:AB[ebx],5  ; если число байтов нечетное
  M:
Добавлено через 11 часов 48 минут
Описался со сдвигом в ECX:
Assembler
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
   xor    ebx,ebx
    push   ds
    pup    fs
    mov    ecx,17 ; размер массива AB в байтах
    shr    ecx,1    ; сдвигаем словами 
    pushf            ; сохраним флаги
  loop0:
    mov    ax,Word Ptr fs:AB[ebx]
    mov    dx,Word Ptr fs:AB[ebx+2]
    shrd   ax,dx,5  ;на 5 битов
    mov    Word Ptr fs:AB[ebx],ax
    inc    ebx       ; чтобы не испортить флаги
    inc    ebx
    loop   loop0
    popf
    jnc    M
    shr    byte Ptr fs:AB[ebx],5  ; если число байтов нечетное
  M:
1
Ушел с форума
Автор FAQ
 Аватар для Mikl___
16373 / 7685 / 1080
Регистрация: 11.11.2010
Сообщений: 13,759
05.02.2013, 10:38
Цитата Сообщение от Dmitrinik Посмотреть сообщение
inc * *ebx * * * ; чтобы не испортить флаги
* * inc * *ebx
Dmitrinik,
inc и dec не воздействуют только на флаг CF, чтобы действительно не воздействовать на флаги нужно вызывать команду lea ebx,[ebx+2]
0
539 / 399 / 99
Регистрация: 18.08.2012
Сообщений: 1,024
05.02.2013, 13:04
Цитата Сообщение от Mikl___ Посмотреть сообщение
Dmitrinik,
inc и dec не воздействуют только на флаг CF, чтобы действительно не воздействовать на флаги нужно вызывать команду lea ebx,[ebx+2]
Премного благодарствуем за науку, но в данном случае именно CF и нужен
0
0 / 0 / 0
Регистрация: 19.03.2012
Сообщений: 20
05.02.2013, 13:06  [ТС]
Спасибо! Идею я понял, но внятный результат получить не могу:

Просто для себя в процедуру написал
Assembler
1
2
3
4
        mov ax, word ptr fs:array[bx]
    mov dx, word ptr fs:array[bx+2]
    shrd ax,dx,5
    mov word ptr fs:array[bx],ax
В итоге первые 2 символа просто заменяются на буквы
0
539 / 399 / 99
Регистрация: 18.08.2012
Сообщений: 1,024
05.02.2013, 13:55
Цитата Сообщение от Ryk Посмотреть сообщение
Спасибо! Идею я понял, но внятный результат получить не могу:
В итоге первые 2 символа просто заменяются на буквы
А "внятный результат" - это что? Естественно, при сдвиге меняются значения в байтах. Например, если во всех байтах было значение 9 (00001001b), то после сдвига на 1 бит во всех байтах будет по 132 (10000100b).
0
0 / 0 / 0
Регистрация: 19.03.2012
Сообщений: 20
05.02.2013, 15:36  [ТС]
Извиняйте, возможно я не понял задания, да и ассемблер мне тяжеловато дается.
Получается каждый элемент массива хранится в байте. и мы из каждого байта 5 бит сдвигаем в другой байт?
Если обьявление массива в таком виде array db 1,2,3,4,5
0
539 / 399 / 99
Регистрация: 18.08.2012
Сообщений: 1,024
05.02.2013, 16:03
"Пять битов из одного байта - в другой" и "Сдвиг всего массива на 5 битов" - это разные задачи. Надо смотреть предметную часть задачи, а тогда уже станет ясно, как ее решать.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
05.02.2013, 16:03
Помогаю со студенческими работами здесь

Циклический сдвиг массива
Удалить три элемента массива Z, состоящий из n элементов, начиная с x - того.

Циклический сдвиг массива
Дан массив: 0123456 0123456 0123456 0123456 0123456 Как осуществить сдвиг таким образом: 6012345 6012345

Циклический сдвиг массива
Задание такое. Нужно циклически сдвинуть массив на К элементов вправо. Я сделал сдвиг, только он выбирает К-ый элемент с конца, а мне нужно...

Циклический сдвиг массива
Задан линейный массив. Осуществить в нем сдвиги по следующему правилу: циклически сдвинуть на с элементов влево. Число с вводится. ...

Циклический сдвиг массива
Нужно решение пока не хватает знаний =) 1. Дан массив x из n элементов. Найдите x1−x2+x3−…−xn−1+xn. ...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
8
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 12.02.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами и вызывать обработчики событий столкновения. . . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 11.02.2026
Содержание блога Библиотека SDL3 содержит встроенные инструменты для базовой работы с изображениями - без использования библиотеки SDL3_image. Пошагово создадим проект для загрузки изображения. . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL3_image
8Observer8 10.02.2026
Содержание блога Библиотека SDL3_image содержит инструменты для расширенной работы с изображениями. Пошагово создадим проект для загрузки изображения формата PNG с альфа-каналом (с прозрачным. . .
Установка Qt-версии Lazarus IDE в Debian Trixie Xfce
volvo 10.02.2026
В общем, достали меня глюки IDE Лазаруса, собранной с использованием набора виджетов Gtk2 (конкретно: если набирать текст в редакторе и вызвать подсказку через Ctrl+Space, то после закрытия окошка. . .
SDL3 для Web (WebAssembly): Работа со звуком через SDL3_mixer
8Observer8 08.02.2026
Содержание блога Пошагово создадим проект для загрузки звукового файла и воспроизведения звука с помощью библиотеки SDL3_mixer. Звук будет воспроизводиться по клику мышки по холсту на Desktop и по. . .
SDL3 для Web (WebAssembly): Основы отладки веб-приложений на SDL3 по USB и Wi-Fi, запущенных в браузере мобильных устройств
8Observer8 07.02.2026
Содержание блога Браузер Chrome имеет средства для отладки мобильных веб-приложений по USB. В этой пошаговой инструкции ограничимся работой с консолью. Вывод в консоль - это часть процесса. . .
SDL3 для Web (WebAssembly): Обработчик клика мыши в браузере ПК и касания экрана в браузере на мобильном устройстве
8Observer8 02.02.2026
Содержание блога Для начала пошагово создадим рабочий пример для подготовки к экспериментам в браузере ПК и в браузере мобильного устройства. Потом напишем обработчик клика мыши и обработчик. . .
Философия технологии
iceja 01.02.2026
На мой взгляд у человека в технических проектах остается роль генерального директора. Все остальное нейронки делают уже лучше человека. Они не могут нести предпринимательские риски, не могут. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru