• 15 апреля стартует «Курс «SQL-injection Master» ©» от команды The Codeby

    За 3 месяца вы пройдете путь от начальных навыков работы с SQL-запросами к базам данных до продвинутых техник. Научитесь находить уязвимости связанные с базами данных, и внедрять произвольный SQL-код в уязвимые приложения.

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

    Запись на курс до 25 апреля. Получить промодоступ ...

Проверить делимость на число 3, используя только сложение и битовые оп

  • Автор темы temster
  • Дата начала
Статус
Закрыто для дальнейших ответов.
T

temster

Предисловие. Не так давно столкнулся с задачей, которая сформулирована в заголовке поста. Если бы в задании не содержалось части после запятой все понятно: в языке С++ есть операция % - взятие остатка от деления, если остаток 0, то делится, иначе нет….., но! Как же это реализовать используя только сложение и побитовые операции… После часа раздумий вместе с великим мозгом по имени Интернет, у меня на листке созрел алгоритм. Вот его реализация:
 
G

grigsoft

Традиционный метод - если сумма цифр делится на 3. У тебя - аналогичное, но число раскладывается по степеням 4. Доказательство тоже аналогичное - остаток от деления любой степени 4 на 3 - всегда 1, так что делимость определяется суммой коэффициентов разложения. Единственно, что у тебя считается не 219 -> 2+1+9, а 219 -> 21+9, но с точки зрения математики сути это не меняет.
 
Статус
Закрыто для дальнейших ответов.
Мы в соцсетях:

Обучение наступательной кибербезопасности в игровой форме. Начать игру!