from itertools import product
b = int(input())
p = int(input())
t = int(input())
c = []
for _ in range(t):
m = input().strip()
s = int(input().strip())
c.append((m, s))
r = 0
for x in product(range(b), repeat=p):
valid = True
for m, s in c:
if sum(x[i] for i in range(p) if m[i] == '1') != s:
valid = False
break
if valid:
r += 1
print(r)
Ограничение по времени: 1 секунда
Ограничение по памяти: 256 мегабайт
В разведывательное управление доставили сейф с секретной информацией, кодовый замок на котором открывается комбинацией из п цифр, каждая цифра может принимать в различных значений от 0 до 6 - 1. Код неизвестен, однако разведчики передали несколько донесений о том, что сумма цифр кода в некоторых заданных позициях равна какому-то известному числу. Используя информацию из всех полученных донесений, определите, сколько существует возможных кодов, удовлетворяющих этим условиям.
Формат входных данных
Первая строка входных данных содержит числов цифры кода, 2 << 10.
количество различных значений одной
Вторая строка содержит число п количество цифр в коде, п≥ 1, b≤ 60000. Третья строка содержит число t - количество имеющихся донесений о сумме каких-то цифр кода, ≥ 1.
Следующие 2 строк содержат информацию об имеющихся донесениях. Каждое донесен ие состоит из двух строк. Первая из этих строк («маска цифр») содержит и символов, записанных слитно и равных «0» или «1», где цифра «1» обозначает, что в донесении говорится об этой цифре кода. Например, маска цифр «01011» означает сумму цифр, стоящих коде на 2-й, 4-й и 5-й позициях. Во второй строке донесения записано число 8, равное сумме цифр кода, стоящих на данных позициях.Гарантируется, что каждая маска цифр содержит хотя бы одну единицу и что все маски цифр различаются. Общее число донесений может быть любым, удовлетворяющим этим
условиям.
Формат выходных данных
Программа должна вывести одно целое число
количество различных кодов, которые
удовлетворяют всем донесениям.
Система оценки
Решения, правильно работающие, когда п≤4 и каждая маска цифр содержит ровно один символ «1», будут оцениваться в 28 баллов.
Решения, правильно работающие, когда п≤ 4, будут оцениваться в 64 балла.
Замечание
В примере из условия каждая цифра кода может принимать 8 различных значений от 0 до 7; код состоит из Зцифр. Получено 2 донесения, из первого донесения известно, что сумма первой и второй цифр кода равна 7, из второго донесения известно, что сумма второй и третьей цифр кода равна 12. Существуют 3 кода, удовлетворяющие этим условиям: «075», «166», «257».