Есть два флага участия в экспериментах: in_ab_test = 1 и in_holdout = 1. Нужно выбрать пользователей, которые не находятся ни в одном из них. Какое условие корректно?
A
NOT (in_ab_test = 1) OR NOT (in_holdout = 1)B
in_ab_test = 0 OR in_holdout = 0C
NOT (in_ab_test = 1) AND NOT (in_holdout = 1)D
NOT (in_ab_test = 1 AND in_holdout = 1)Правильный ответ. Фраза «ни в одном из них» для двух флагов означает
NOT (in_ab_test = 1) AND NOT (in_holdout = 1).Разбор
Чтобы пользователь не был ни в одном из сегментов, оба условия участия должны быть ложными одновременно, значит нужен AND. Ошибка — использовать OR: тогда достаточно, чтобы один флаг был ложным, и пользователь пройдёт, даже если другой флаг истинный. По De Morgan это также эквивалентно NOT (in_ab_test = 1 OR in_holdout = 1).
Проверь себя · 1/3разбор после ответа
Какое условие эквивалентно
NOT (is_paying = 1 AND has_subscription = 1) по правилу De Morgan?Ещё вопросы по теме «Булева логика и фильтры»
- Какому выражению со скобками эквивалентно условие `is_new = 1 OR is_paying = 1 AND has_coupon = 1`, если `AND` выполняется раньше `OR`?
- В фильтре написали `country = 'RU' AND device = 'ios' OR device = 'android'`. Какой набор строк реально пройдёт фильтр при стандартном приоритете, где `AND` сильнее `OR`?
- Какое условие эквивалентно `NOT (is_paying = 1 AND has_subscription = 1)` по правилу `De Morgan`?
- Вы хотите выбрать строки, которые не относятся к `country = 'RU' OR country = 'KZ'`. Какое выражение соответствует `NOT (country = 'RU' OR country = 'KZ')` по правилу `De Morgan`?
- В таблице пользователей есть флаги `has_email_optin` и `has_push_optin` (0 или 1). Нужно выбрать пользователей, у которых включён ровно один канал (email или push, но не оба). Какое условие корректно?
- Все вопросы по «Булева логика и фильтры» →