|
24 / 24 / 0
Регистрация: 08.09.2010
Сообщений: 136
|
||||||
Задачка на пошевелить чуть-чуть мозгами (Нужно получить ноль, если в регистре ноль, и единицу в обратном случае)11.12.2011, 00:38. Показов 3455. Ответов 27
Метки нет (Все метки)
В процессе написания кода столкнулся с одной задачей, которая показалась мне интересной и я хотел бы поделиться ей с вами и послушать альтернативные варианты реализации, коль таковые имеются.
В регистре есть число. Нужно получить ноль, если в регистре ноль, и единицу в обратном случае. Казалось бы, тривиально, таковым и является. Однако усложним задачу, запретив использовать условные и безусловные переходы. То есть, алгоритм, реализующий это без ветвлений. Мой вариант под катом, но советую в начале самим пошевелить мозгами Свои варианты пожалуйста также постите под кат.ответ
Код AT&T x64.
Пусть исходное число лежит в %rax
0
|
||||||
| 11.12.2011, 00:38 | |
|
Ответы с готовыми решениями:
27
файл вещественных чисел, нужно поравить код совсем чуть-чуть Немогу разобраться в программе нужно пожалуйста чуть чуть дописать её!
|
|
2537 / 833 / 10
Регистрация: 31.05.2009
Сообщений: 1,668
|
||||||
| 11.12.2011, 01:27 | ||||||
|
Первое что в голову
пришло
0
|
||||||
|
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
|
|
|
Ушел с форума
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
|
|
|
768 / 312 / 11
Регистрация: 27.05.2011
Сообщений: 703
|
||||||
| 12.12.2011, 07:48 | ||||||
|
обшибся
,хотя нет, знаю вариант получше: вот
Добавлено через 14 минут DKOI, а вообще, что за задача стояла перед тобой?, просто то, что ты предложил, на мой взгляд не несёт никакой смысловой нагрузки, а только код "пузырит", ладно я б понял если б тебе с 1 на 0 и наоборот поменять нужно, а так, я чёт недогоняю.
0
|
||||||
|
Ушел с форума
16373 / 7685 / 1080
Регистрация: 11.11.2010
Сообщений: 13,759
|
|
| 12.12.2011, 09:20 | |
|
zzzyyyxxx, я тоже в качестве решения сперва предложил NOP, но потом перечитал задание и понял, что ТС хотел -- в случае если в регистре нулевое значение чтобы возвращался 0 и возвращалась единичка в случае ненулевого значения
0
|
|
|
768 / 312 / 11
Регистрация: 27.05.2011
Сообщений: 703
|
||
| 12.12.2011, 10:46 | ||
|
Mikl___, спасибо за уточнение
0
|
||
|
Ушел с форума
16373 / 7685 / 1080
Регистрация: 11.11.2010
Сообщений: 13,759
|
||
| 12.12.2011, 10:56 | ||
|
еще один вариант
mov ebx,1
test eax,eax cmovnz eax,ebx
1
|
||
|
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 | ||
|
0
|
||
|
768 / 312 / 11
Регистрация: 27.05.2011
Сообщений: 703
|
||||||
| 12.12.2011, 23:09 | ||||||
|
мои мозги шАвелятся медленно, но вариант покороче на 1 байт чем выше...
(насчёт скорости выполнения не в курсе,..) моЁ
1
|
||||||
|
4190 / 1838 / 221
Регистрация: 06.10.2010
Сообщений: 4,124
|
||||||
| 26.06.2013, 11:22 | ||||||
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 строк не выходит
0
|
||||||
|
539 / 399 / 99
Регистрация: 18.08.2012
Сообщений: 1,024
|
||||||
| 27.06.2013, 12:23 | ||||||
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
2391 / 525 / 69
Регистрация: 01.06.2011
Сообщений: 3,639
|
||||||
| 28.06.2013, 07:16 | ||||||
0
|
||||||
|
4190 / 1838 / 221
Регистрация: 06.10.2010
Сообщений: 4,124
|
|
| 28.06.2013, 07:34 | |
|
Если заменить rol на rcl, то будет работать при условии, что eax!=1 (для eax=1 выдаст 0).
0
|
|
|
programmer
2391 / 525 / 69
Регистрация: 01.06.2011
Сообщений: 3,639
|
|
| 28.06.2013, 07:39 | |
|
молодца,я вся ночь просто не спал.что пришло ,то написал.
если бы div на 0 делил еще.
0
|
|
| 28.06.2013, 07:39 | |
|
Помогаю со студенческими работами здесь
20
Какие именно темы в математике нужно выучить, чтобы начать хоть чуть-чуть понимать математический анализ и всё остальное Когда я соединяю комп и телевизор через Tv-Out, кабель чуть чуть искрит. Некорректно работает ListListener и еще чуть-чуть всякого стаффа Много текста на одной странице или по чуть-чуть на нескольких? Отнять последнюю строку от остальных (чуть-чуть исправить код) Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
Новые блоги и статьи
|
|||
|
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. Пошагово создадим проект для загрузки изображения. . .
|