Задание 2. Информатика. 2023-13

Просмотры: 175
Изменено: 24 ноября 2024

Миша заполнял таблицу истинности логической функции \(F\) $$ ((x \equiv \neg y) \lor (x \equiv \neg z)) \land w \land (y \to z), $$ но успел заполнить лишь фрагмент из четырёх различных её строк, даже не указав, какому столбцу таблицы соответствует каждая из переменных \(w\), \(x\), \(y\), \(z\).

F
01  1
001
001
1101

Определите, какому столбцу таблицы соответствует каждая из переменных \(w\), \(x\), \(y\), \(z\).
В ответе напишите буквы \(w\), \(x\), \(y\), \(z\) в том порядке, в котором идут соответствующие им столбцы (сначала буква, соответствующая первому столбцу; затем буква, соответствующая второму столбцу, и т.д.). Буквы в ответе пишите подряд, никаких разделителей между буквами ставить не нужно.

Пример. Функция \(F\) задана выражением \( \neg x \lor y\), зависящим от двух переменных, а фрагмент таблицы имеет следующий вид:

F
010

В этом случае первому столбцу соответствует переменная \(y\), а второму — переменная \(x\). В ответе следует написать: \(yx\).

Решение:

Python


from itertools import permutations, product

def F(x, y, z, w):
    return ((x == (not y)) or (x == (not z))) and w and (y <= z)

for perm in permutations('xyzw'):
    for a,b,c,d,e,f,g in product([0,1], repeat=7):
        table = [[0,1,a,b,1],
                 [0,c,0,d,1],
                 [e,0,0,f,1],
                 [1,1,0,g,1]]
        if table[0] == table[1] or table[1] == table[2]:
            continue
        if all(F(**dict(zip(perm,row))) == row[-1] for row in table):
            print(*perm)

Ответ: \(xzyw\)