С Новым годом! Форум программистов, компьютерный форум, киберфорум
Turbo Pascal
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.57/7: Рейтинг темы: голосов - 7, средняя оценка - 4.57
0 / 0 / 0
Регистрация: 21.01.2018
Сообщений: 5

Программа на паскале с использованием ассемблерных вставок

21.01.2018, 23:05. Показов 1363. Ответов 7
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Очень нужна помощь. Нужен код, написанный на языке паскаля с применением ассемблерных вставок и в теле программы обрабатывающий строку из 1234567 в 6712345, то есть перестановки 6 и 7 элемента строки в начало строки, причём: если ввести начальную строку 123456 или 12345, то перестановок быть не должно или 12345671234567, то должно стать 67123456712345, то есть своеобразный цикл зависящий от длины строки
0
Лучшие ответы (1)
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
21.01.2018, 23:05
Ответы с готовыми решениями:

Использование ассемблерных вставок
эта тема о тех задачах которые сложно/невозможно решить на Си++ без использования ассемблерных вставок. делитесь опытом товарищи!!!

Оптимизировать hello, world без ассемблерных вставок
Доброго времени суток. Цель - оптимизировать hello, world без ассемблерных вставок. Насколько я понимаю, printf довольно объемная...

Использование ассемблерных вставок для работы с вектором
Народ помогите исправить ошибку, отметил строчку в коде!!! #include <vector> #include <iostream> using namespace std; void...

7
Модератор
Эксперт Pascal/DelphiЭксперт NIX
 Аватар для bormant
7816 / 4635 / 2837
Регистрация: 22.11.2013
Сообщений: 13,158
Записей в блоге: 1
22.01.2018, 11:22
Например:
Pascal
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
var s: String;
begin
  Write('> '); ReadLn(s);
  asm
    xor bx,bx
    mov bl,byte ptr s
    cmp bl,7
    jb  @done
    dec bx
    mov dx,word ptr s[bx]
  @1:
    mov al,byte ptr s[bx]
    mov byte ptr s[bx+2],al
    dec bx
    jnz @1
    mov word prt s[1],dx
  @done:
  end;
  WriteLn('= ',s);
end.
Добавлено через 1 минуту
Это было вращение строки вправо на 2 символа.
Если вдруг имелось в виду что-то другое -- уточняйте.

Добавлено через 2 минуты
Цитата Сообщение от Obiiii Посмотреть сообщение
12345671234567, то должно стать 67123456712345
А если длина строки не кратна 7, что должно быть тогда?
1
0 / 0 / 0
Регистрация: 21.01.2018
Сообщений: 5
23.01.2018, 22:13  [ТС]
Если 12345 или 123456 не менять - это и есть условия кратности , тоесть если 1234567123456,то тоже не менять 2 часть , 1 нужно изменить , код убирает первые 2 символа ,но их не нужно убирать , а изменить на 6-7 и подвинуть строку 12345 вправо
0
Модератор
Эксперт Pascal/DelphiЭксперт NIX
 Аватар для bormant
7816 / 4635 / 2837
Регистрация: 22.11.2013
Сообщений: 13,158
Записей в блоге: 1
23.01.2018, 22:15
То есть, разбить строку на куски по 7 элементов, в каждый кусок сдвинуть циклически вправо на 2 позиции. Если последний кусок меньше 7, не изменять его. Так?
0
0 / 0 / 0
Регистрация: 21.01.2018
Сообщений: 5
23.01.2018, 23:16  [ТС]
Цитата Сообщение от bormant Посмотреть сообщение
То есть, разбить строку на куски по 7 элементов, в каждый кусок сдвинуть циклически вправо на 2 позиции. Если последний кусок меньше 7, не изменять его. Так?
1.Так точно разбить на 7
2.Не совсем сдвинуть , потому что сдвигаем только 12345 , а 67 ставим вперёд что было)1234567->(что получится)6712345
3.Так точно
0
Модератор
Эксперт Pascal/DelphiЭксперт NIX
 Аватар для bormant
7816 / 4635 / 2837
Регистрация: 22.11.2013
Сообщений: 13,158
Записей в блоге: 1
24.01.2018, 00:44
Pascal
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
const GLen=7;
var s: String;
begin
  {ReadLn(s);} s:='12345671234567123456'; 
  asm
    xor si,si
    xor cx,cx
    mov al,byte ptr s
  @1:
    sub al,GLen
    jb  @2
    inc cx
    jmp @1
  @2:
    mov bx,GLen-2
    mov dx,word ptr s[1+si+bx]
  @3:
    mov al,byte ptr s[si+bx]
    mov byte ptr s[2+si+bx],al
    dec bx
    jnz @3
  @4:
    mov word ptr s[1+si],dx
    add si,GLen
    loop @2
  end;
  WriteLn(s);
end.
0
0 / 0 / 0
Регистрация: 21.01.2018
Сообщений: 5
24.01.2018, 10:10  [ТС]
Спасибо огромное!!!!!!!!!!!!!!!
0
Модератор
Эксперт Pascal/DelphiЭксперт NIX
 Аватар для bormant
7816 / 4635 / 2837
Регистрация: 22.11.2013
Сообщений: 13,158
Записей в блоге: 1
24.01.2018, 10:45
Лучший ответ Сообщение было отмечено Obiiii как решение

Решение

Пока не за что, нужна еще одна проверка на случай длины менее 7:
Pascal
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
const GLen=7;
var s: String;
begin
  {ReadLn(s);} s:='12345671234567123456'; 
  asm
    xor si,si
    xor cx,cx
    mov al,byte ptr s
  @1:
    sub al,GLen
    jb  @2
    inc cx
    jmp @1
  @2:
    jcxz @done
  @nextGroup:
    mov bx,GLen-2
    mov dx,word ptr s[1+si+bx]
  @nextChar:
    mov al,byte ptr s[si+bx]
    mov byte ptr s[2+si+bx],al
    dec bx
    jnz @nextChar
    mov word ptr s[1+si],dx
    add si,GLen
    loop @nextGroup
  @done:
  end;
  WriteLn(s);
end.
Добавлено через 17 минут
7-14: деление вычитанием, CX:=Length(s) div GLen
15: если CX=0 -- выходим
16-26: обработка очередной группы
17-18: DX:=последние 2 символа группы
19-23: сдвигаем группу вправо на 2 символа
24: запишем DX в начало группы
25: сдвинем SI -- начало следующей группы -- на GLen
26: уменьшим CX, если CX<>0 идем на nextGroup
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
24.01.2018, 10:45
Помогаю со студенческими работами здесь

Подскажите компилятор С++, для ассемблерных вставок на х64 код
Подскажите компилятор С++ который понимает inline ассемблерные вставки на х64 код.

Создание ассемблерных программ с использованием процедур, условных и безусловных переходов и циклов
Прошу помочь с лабораторкой. Дали задание, но ничего не объяснили, очень трудно удается делать это. Может кто-то рабочий код к похожему...

Написание модуля на C с использованием вставок asm
Столкнулся с такой проблемой. Писал модуль на языке С. Нужно было заменить время выполнения функций. Но функции ассемблеровские, например:...

Сумма с использованием условных операторов в паскале
Помогите пожалуйста с задачей Имя входного файла: sum_in.txt или стандартный поток ввода Имя выходного файла: sum_out.txt или...

Написание программы на паскале с использованием цикла
Вообщем нужно написать программу, которая в цикле введете 11 значений и посчитает среднее арифметическое позитивных чисел, и среднее...


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

Или воспользуйтесь поиском по форуму:
8
Ответ Создать тему
Новые блоги и статьи
Модель микоризы: классовый агентный подход 3
anaschu 06.01.2026
aa0a7f55b50dd51c5ec569d2d10c54f6/ O1rJuneU_ls https:/ / vkvideo. ru/ video-115721503_456239114
Owen Logic: О недопустимости использования связки «аналоговый ПИД» + RegKZR
ФедосеевПавел 06.01.2026
Owen Logic: О недопустимости использования связки «аналоговый ПИД» + RegKZR ВВЕДЕНИЕ Введу сокращения: аналоговый ПИД — ПИД регулятор с управляющим выходом в виде числа в диапазоне от 0% до. . .
Модель микоризы: классовый агентный подход 2
anaschu 06.01.2026
репозиторий https:/ / github. com/ shumilovas/ fungi ветка по-частям. коммит Create переделка под биомассу. txt вход sc, но sm считается внутри мицелия. кстати, обьем тоже должен там считаться. . . .
Расчёт токов в цепи постоянного тока
igorrr37 05.01.2026
/ * Дана цепь постоянного тока с сопротивлениями и напряжениями. Надо найти токи в ветвях. Программа составляет систему уравнений по 1 и 2 законам Кирхгофа и решает её. Последовательность действий:. . .
Новый CodeBlocs. Версия 25.03
palva 04.01.2026
Оказывается, недавно вышла новая версия CodeBlocks за номером 25. 03. Когда-то давно я возился с только что вышедшей тогда версией 20. 03. С тех пор я давно снёс всё с компьютера и забыл. Теперь. . .
Модель микоризы: классовый агентный подход
anaschu 02.01.2026
Раньше это было два гриба и бактерия. Теперь три гриба, растение. И на уровне агентов добавится между грибами или бактериями взаимодействий. До того я пробовал подход через многомерные массивы,. . .
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост.
Programma_Boinc 28.12.2025
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост. Налог на собак: https:/ / **********/ gallery/ V06K53e Финансовый отчет в Excel: https:/ / **********/ gallery/ bKBkQFf Пост отсюда. . .
Кто-нибудь знает, где можно бесплатно получить настольный компьютер или ноутбук? США.
Programma_Boinc 26.12.2025
Нашел на реддите интересную статью под названием Anyone know where to get a free Desktop or Laptop? Ниже её машинный перевод. После долгих разбирательств я наконец-то вернула себе. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru