Форум программистов, компьютерный форум, киберфорум
Assembler: математика, вычисления
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
 
Рейтинг 4.50/18: Рейтинг темы: голосов - 18, средняя оценка - 4.50
 Аватар для DKOI
24 / 24 / 0
Регистрация: 08.09.2010
Сообщений: 136

Задачка на пошевелить чуть-чуть мозгами (Нужно получить ноль, если в регистре ноль, и единицу в обратном случае)

11.12.2011, 00:38. Показов 3455. Ответов 27
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
В процессе написания кода столкнулся с одной задачей, которая показалась мне интересной и я хотел бы поделиться ей с вами и послушать альтернативные варианты реализации, коль таковые имеются.
В регистре есть число. Нужно получить ноль, если в регистре ноль, и единицу в обратном случае. Казалось бы, тривиально, таковым и является. Однако усложним задачу, запретив использовать условные и безусловные переходы. То есть, алгоритм, реализующий это без ветвлений. Мой вариант под катом, но советую в начале самим пошевелить мозгами Свои варианты пожалуйста также постите под кат.
ответ
Код AT&T x64.
Пусть исходное число лежит в %rax
Assembler
1
2
3
4
5
6
add %rax, %rax; складываем %rax с самим собой
pushf; кладем в стек регистр флагов
pop %rax; и достаем его в %rax
shr $6, %rax; переносим ZF в нулевой бит регистра
not %rax; инвертируем его значение
andq $1, %rax; и зануляем лишние биты
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
11.12.2011, 00:38
Ответы с готовыми решениями:

файл вещественных чисел, нужно поравить код совсем чуть-чуть
Вот написал, но работает только для целых чисел.Как сделать для файла с вещественными числами? #include <stdio.h> #include...

Немогу разобраться в программе нужно пожалуйста чуть чуть дописать её!
Уже вроде все написал.И должно работать!! Но не хочет рисовать незнаю почему, если кто нибудь исправит и все выше описанное заработает буду...

Если в матрице встречается ноль, то нужно обнулить столбец и строку, где находится этот ноль
Дан двумерный массив n на m. Если в массиве встречается ноль, то нужно обнулить столбец и строку ,где находится этот ноль.

27
 Аватар для Goodwin98
2537 / 833 / 10
Регистрация: 31.05.2009
Сообщений: 1,668
11.12.2011, 01:27
Первое что в голову
пришло
Assembler
1
2
3
test eax,eax
mov eax,0
setne al
0
 Аватар для DKOI
24 / 24 / 0
Регистрация: 08.09.2010
Сообщений: 136
11.12.2011, 01:53  [ТС]
Не знал про эту команду Так действительно проще
0
273 / 268 / 11
Регистрация: 24.12.2010
Сообщений: 328
11.12.2011, 02:46
мой вариант
sub ax,1
mov ax,0
adc ax,0
xor ax,1
0
Ушел с форума
Автор FAQ
 Аватар для Mikl___
16373 / 7685 / 1080
Регистрация: 11.11.2010
Сообщений: 13,759
12.12.2011, 07:13
два моих варианта
1) neg eax
sbb eax,eax
and eax,1
2) neg eax
db 0D6h; SALC (Set AL Carry flag)
and eax,1
1
 Аватар для zzzyyyxxx
768 / 312 / 11
Регистрация: 27.05.2011
Сообщений: 703
12.12.2011, 07:48
обшибся ,
хотя нет, знаю вариант получше:
вот

Assembler
1
       ;а нафиг вообще что-то делать если результат будет тот-же?


Добавлено через 14 минут
DKOI, а вообще, что за задача стояла перед тобой?, просто то, что ты предложил, на мой взгляд не несёт никакой смысловой нагрузки, а только код "пузырит",
ладно я б понял если б тебе с 1 на 0 и наоборот поменять нужно, а так, я чёт недогоняю.
0
Ушел с форума
Автор FAQ
 Аватар для Mikl___
16373 / 7685 / 1080
Регистрация: 11.11.2010
Сообщений: 13,759
12.12.2011, 09:20
zzzyyyxxx, я тоже в качестве решения сперва предложил NOP, но потом перечитал задание и понял, что ТС хотел -- в случае если в регистре нулевое значение чтобы возвращался 0 и возвращалась единичка в случае ненулевого значения
0
 Аватар для zzzyyyxxx
768 / 312 / 11
Регистрация: 27.05.2011
Сообщений: 703
12.12.2011, 10:46
Mikl___, спасибо за уточнение
Цитата Сообщение от Mikl___ Посмотреть сообщение
1) neg eax
sbb eax,eax
and eax,1
по моему neg здесь ни к чему..., а если так, то у тебя самый лучший вариант, но эт пока...
0
Ушел с форума
Автор FAQ
 Аватар для Mikl___
16373 / 7685 / 1080
Регистрация: 11.11.2010
Сообщений: 13,759
12.12.2011, 10:56
Цитата Сообщение от zzzyyyxxx Посмотреть сообщение
по моему neg здесь ни к чему...,
как это ни к чему? получить CarryFlag=1 можно через SUB, ADD, CMP и сдвиги; в данном случае NEG REG == (SUB 0,REG) можно конечно и Zero Flag анализировать через TEST, OR, AND но для получения значения в ZF можно воспользоваться только POPF и SAHF, хотя есть еще вариант через "divide by zero"
еще один вариант
mov ebx,1
test eax,eax
cmovnz eax,ebx
1
 Аватар для zzzyyyxxx
768 / 312 / 11
Регистрация: 27.05.2011
Сообщений: 703
12.12.2011, 11:06
точно!, ......извиняй!
0
273 / 268 / 11
Регистрация: 24.12.2010
Сообщений: 328
12.12.2011, 11:13
Цитата Сообщение от Mikl___ Посмотреть сообщение
1) neg eax
sbb eax,eax
and eax,1
Тоже понравился вариант. Не знал, что neg устанавливает cf при ненулевом результате.
0
 Аватар для zzzyyyxxx
768 / 312 / 11
Регистрация: 27.05.2011
Сообщений: 703
12.12.2011, 23:09
мои мозги шАвелятся медленно, но вариант покороче на 1 байт чем выше...
(насчёт скорости выполнения не в курсе,..)
моЁ
Assembler
1
2
    bsf eax,eax
    setne al
1
4190 / 1838 / 221
Регистрация: 06.10.2010
Сообщений: 4,124
26.06.2013, 11:22
Assembler
1
2
bsr ecx,eax
shr eax,cl
0
2642 / 1653 / 267
Регистрация: 19.02.2010
Сообщений: 4,383
26.06.2013, 23:31
@DKOI, ещё один двухстрочный вариант собирается из test и cmov..
0
4190 / 1838 / 221
Регистрация: 06.10.2010
Сообщений: 4,124
27.06.2013, 07:27
У меня меньше 3 строк не выходит
Assembler
1
2
3
mov    edx,1
test   eax,eax
cmovne eax,edx
0
539 / 399 / 99
Регистрация: 18.08.2012
Сообщений: 1,024
27.06.2013, 12:23
Assembler
1
2
shr   eax,31
adc   eax,0
0
4190 / 1838 / 221
Регистрация: 06.10.2010
Сообщений: 4,124
27.06.2013, 12:29
@Dmitrinik
Это эквивалентно eax = ((eax shr 30) and 1)+(eax shr 31). Не то.
0
programmer
 Аватар для Thread
2391 / 525 / 69
Регистрация: 01.06.2011
Сообщений: 3,639
28.06.2013, 07:16
Assembler
1
2
imul eax,eax,80000000h
rol  eax,1
0
4190 / 1838 / 221
Регистрация: 06.10.2010
Сообщений: 4,124
28.06.2013, 07:34
Если заменить rol на rcl, то будет работать при условии, что eax!=1 (для eax=1 выдаст 0).
0
programmer
 Аватар для Thread
2391 / 525 / 69
Регистрация: 01.06.2011
Сообщений: 3,639
28.06.2013, 07:39
молодца,я вся ночь просто не спал.что пришло ,то написал.
если бы div на 0 делил еще.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
28.06.2013, 07:39
Помогаю со студенческими работами здесь

Какие именно темы в математике нужно выучить, чтобы начать хоть чуть-чуть понимать математический анализ и всё остальное
Здравствуйте, не знаю в правильном ли я месте спрашиваю, но любой совет поможет. Я студент 1 курса, сегодня перевёлся на направление...

Когда я соединяю комп и телевизор через Tv-Out, кабель чуть чуть искрит.
Всем привет. Есть такой вопрос. Когда я соединяю комп и телевизор через Tv-Out, кабель чуть чуть искрит. Если я беру другой кабель, не...

Некорректно работает ListListener и еще чуть-чуть всякого стаффа
Всем привет! Я постигаю вощем java потихоньку... вот у меня возникло пара вопросов: 1)почему у меня два раза в JList записываются...

Много текста на одной странице или по чуть-чуть на нескольких?
В процессе оформления перечня и описания услуг на сайте компании я озадачился следующей вещью. Как лучше разместить информацию на сайте,...

Отнять последнюю строку от остальных (чуть-чуть исправить код)
Надо последнею строку матрицы отнять от всех остальных, у меня это получилось сделать, но в условии сказано что последняя строка должна...


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

Или воспользуйтесь поиском по форуму:
20
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Реализация движения на Box2D v3 - трение и коллизии с повёрнутыми стенами
8Observer8 20.02.2026
Содержание блога Box2D позволяет легко создать главного героя, который не проходит сквозь стены и перемещается с заданным трением о препятствия, которые можно располагать под углом, как верхнее. . .
Конвертировать закладки radiotray-ng в m3u-плейлист
damix 19.02.2026
Это можно сделать скриптом для PowerShell. Использование . \СonvertRadiotrayToM3U. ps1 <path_to_bookmarks. json> Рядом с файлом bookmarks. json появится файл bookmarks. m3u с результатом. # Check if. . .
Семь CDC на одном интерфейсе: 5 U[S]ARTов, 1 CAN и 1 SSI
Eddy_Em 18.02.2026
Постепенно допиливаю свою "многоинтерфейсную плату". Выглядит вот так: https:/ / www. cyberforum. ru/ blog_attachment. php?attachmentid=11617&stc=1&d=1771445347 Основана на STM32F303RBT6. На борту пять. . .
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
И ясному Солнцу
zbw 12.02.2026
И ясному Солнцу, и светлой Луне. В мире покоя нет и люди не могут жить в тишине. А жить им немного лет.
«Знание-Сила»
zbw 12.02.2026
«Знание-Сила» «Время-Деньги» «Деньги -Пуля»
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. Пошагово создадим проект для загрузки изображения. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru