0 / 0 / 1
Регистрация: 01.05.2017
Сообщений: 10
|
||||||
1 | ||||||
FASM Подсчет суммы элементов массива после установки 1 в четвертом бите каждого элемента. Проблемы с выводом в консоль20.03.2020, 13:52. Просмотров 983. Ответов 5
Метки нет Все метки)
(
Форумчане! Помогите!
Необходимо написать код, который позволяет установить "1" в четвертых битах всех элементов массива из 10 байтов. Определить сумму элементов полученного массива. Мне удалось составить макет (скелет) кода и используя интернет составить следующий код:
Не факт конечно, что я правильно написал код, поэтому, если найдете ошибки - сообщите пожалуйста. Буду рад любой полезной информации касательно моей темы. (с ассемблером на "Вы" - пока делаю попытки его изучить в рамках заданий универа...)
0
|
|
20.03.2020, 13:52 | |
Задание массива 3-хзначных чисел, запись в файл и и подсчет суммы цифр каждого элемента
|
|
Модератор
![]() |
|
20.03.2020, 20:27 | 2 |
У вас смесь кода для 16- и 32-разрядного режима процессора.
Значение массива выводят по одному числу. Вывод числа рассмотрен в закреплённой теме Ввод и вывод чисел в различных системах счисления Смысл подпрограммы вывода - исходное число делят на 10 и остатки (цифры от 0 до 9) сохраняют в стеке, а потом выводят остатки на экран по одному.
1
|
0 / 0 / 1
Регистрация: 01.05.2017
Сообщений: 10
|
||||||
21.03.2020, 10:15 [ТС] | 3 | |||||
Прислушавшись к словам ФедосеевПавел, решил всё с нуля переписать и именно самому, получилось следующее:
Кликните здесь для просмотра всего текста
./main
Исходный массив: 6291736 6291736 6291736 6291736 6291736 6291736 6291736 6291736 6291736 6291736 ! 24 Почему так получается - понять не могу... Подскажите пожалуйста
0
|
Модератор
![]() |
|||||||||||
21.03.2020, 17:45 | 4 | ||||||||||
Я так понимаю, что это FASM для Linux x64.
Вывод числа у вас несколько усложнён. Посмотрите пример для беззнакового числа. Как-то в онлайн эмуляторе выводил число для компилятора NASM, но должно быть всё понятно - их синтаксис довольно похож https://www.cyberforum.ru/post14230418.html Сначала преобразовал в строку, а потом одним вызовом вывел эту строку. Т.к. массив Array из элементов в 1 байт, то при выводе нужно расширить RAX нулями или знаковыми битами (в зависимости от формата). Например, для беззнаковых movzx al, rax , а для чисел со знаком movsx al, rax , а потом вызывать процедуру вывода.Для процедур не нужно отдельно объявлять секции. Просто ставьте метку. А визуально выделяйте комментариями в виде множества тире. Перебор элементов массива можно сделать несколькими способами. 1. по указателю
0
|
0 / 0 / 1
Регистрация: 01.05.2017
Сообщений: 10
|
||||||
23.03.2020, 17:06 [ТС] | 5 | |||||
![]() Решение
!!!!Решено!!!!
Рабочий код, всё пофиксил, всё работает:
Кликните здесь для просмотра всего текста
Исходный массив: Преобразованный массив:
24 24 17 17 71 87 98 114 3 19 45 61 76 92 8 24 11 27 9 25 Суммы: 362 490
0
|
Модератор
![]() |
|
23.03.2020, 17:52 | 6 |
Vovka_Nikel,
1. при выводе числа в print_number проверку на нулевое значение делимого нужно проводить после деления - чтобы строка формировалась и при rax=0 на входе в процедуру. Попробуйте один из элементов массива обнулить и поймёте. 2. так и остались разбиения на секции для каждой процедуры - это лишнее.
0
|
23.03.2020, 17:52 | |
Заказываю контрольные, курсовые, дипломные и любые другие студенческие работы здесь. Вывод элементов массива в таблицу с задержкой после каждого элемента Поиск суммы элементов массива, расположенных после минимального элемента Функция нахождения суммы элементов массива, расположенных после максимального элемента Установить 0 в 5-м бите всех эл массива целых чисел с четным индексом и 1 - в 4-м бите всех нечетных эл массива.
Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |