Тема 15. Преобразование логических выражений
15.01 Смешанное
Вспоминай формулы по каждой теме
Решай новые задачи каждый день
Вдумчиво разбирай решения
ШКОЛКОВО.
Готовиться с нами - ЛЕГКО!
Подтемы раздела преобразование логических выражений
Решаем задачу:

Ошибка.
Попробуйте повторить позже

Задача 1#29731

Обозначим через ДЕЛ(n, m) утверждение «натуральное число n делится без остатка на натуральное число m». Обозначим через m&n  поразрядную конъюнкцию неотрицательных целых чисел m  и n  .

На числовой прямой даны отрезки Q = [12;48]  и P = [32,64]  .

Определите наименьшее натуральное число A  , такое что выражение

Д ЕЛ (x,5)∨ (x ∕∈ Q )∨ (x &A = 0)∨ ((x ∈ P) → (|x − 31| ≥ 17))

тождественно истинно, то есть принимает значение 1 при любом целом значении переменной х.

Показать ответ и решение

Решение 1 (ручками):
Система для врагов:

(
||| x|| ... 5
||||
|||{ x ∈ Q
  x&A ⁄= 0
|||
|||| x ∈ P
|||(
  |x − 31| < 17

Раскроем последнее неравенство системы: x− 31 < 17  и x− 31 > − 17  , то есть x < 48  и x > 14  , то есть x ∈ (14;48)  . Враги мечтают, чтобы x ∈ [32;48]  P  и в Q  ), x ∈ (14;48)  и при этом они не делились на 5  . Таким образом, чтобы победить, враги будут брать только следующие иксы: {32,33,34,36,37,38,39,41,42,43,44,46,47} . Также враги мечтают, чтобы x&A ⁄= 0  . Максимальный икс, который могут взять друзья, равен 47  , то есть 1011112  , а минимальный икс = 32  , то есть 1000002  . Отсюда заметим, что ни один икс, подходящий врагам, не содержит единичку в пятом с конца разряде в двоичной записи. Тогда мечты врагов такие: «Вот бы у числа A  была единичка в первом, втором, третьем, четвёртом или шестом с конца разряде в двоичной записи».

Друзья говорят: «Нет, число A  не содержит единичку ни на одном из этих разрядов». Минимальное A  , которое могут взять друзья, равно 100002  , то есть Amin = 16  .

 

Решение 2 (прогой):

def f(x, A):
    Q = [12, 48]
    P = [32, 64]
    return ((x%5 == 0) or (not inn(x, Q)) or (x & A == 0) or ((inn(x, P)) <= (abs(x - 31) >= 17)))

def inn(x, P):
    return P[0] <= x <= P[1]

for A in range(1, 1000):
    flag = True
    for x in range(-1000, 1000):
        if not f(x, A):
            flag = False
            break
    if flag:
        print(A)

Ответ: 16

Специальные программы

Все специальные программы

Программа
лояльности v2.0

Приглашай друзей в Школково и получай вознаграждение до 10%!

Крути рулетку
и выигрывай призы!

Крути рулетку и покупай курсы со скидкой, которая привязывается к вашему аккаунту.

Бесплатное обучение
в Школково

Для детей ДНР, ЛНР, Херсонской, Запорожской, Белгородской, Брянской областей, а также школьникам, находящимся в пунктах временного размещения Крыма обучение на платформе бесплатное.

Налоговые вычеты

Узнай, как получить налоговый вычет при оплате обучения в «Школково».

Специальное предложение
для учителей

Бесплатный доступ к любому курсу подготовки к ЕГЭ или олимпиадам от «Школково». Мы с вами делаем общее и важное дело, а потому для нас очень значимо быть чем-то полезными для учителей по всей России!

Вернём деньги за курс
за твою сотку на ЕГЭ

Сдать экзамен на сотку и получить обратно деньги за подготовку теперь вполне реально!

cyberpunkMouse
cyberpunkMouse
Рулетка
Вы можете получить скидку в рулетке!