Логические операторы

Мы уже умеем писать функции, которые проверяют одиночные условия. Теперь научимся строить составные условия.

Хороший пример: проверка пароля. Как вы знаете, некоторые сайты при регистрации хотят пароль от 8 до 20 символов в длину. Честно говоря, это странное ограничение, но что поделать.

В математике мы бы написали 8 < x < 20, но в Java такой трюк не пройдет (хотя есть языки, в которых пройдет).

Нам придётся сделать два отдельных логических выражения и соединить их специальным оператором «И»:

Пароль длиннее 8 символов И пароль короче 20 символов.

Вот функция, которая принимает пароль и говорит, соответствует ли он условиям (true) или не соответствует (false):


public static boolean isCorrectPassword(String password) {
    int length = password.length();
    return length > 8 && length < 20;
}

public static void main(String[] agrs) {
  isCorrectPassword("qwerty"); // => false
  isCorrectPassword("qwerty1234"); // => true
  isCorrectPassword("zxcvbnmasdfghjkqwertyui"); // => false
}

&& - означает «И» (в математической логике это называют конъюнкцией). Всё выражение считается истинным, только если истинен каждый операнд — каждое из составных выражений. Иными словами, && означает «и то, и другое».

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

Кроме && часто используется оператор || — «ИЛИ» (дизъюнкция). Он означает «или то, или другое, или оба».

Операторы можно комбинировать в любом количестве и любой последовательности, но когда одновременно встречаются && и ||, то приоритет лучше задавать скобками.


Другой пример. Мы хотим купить квартиру, которая удовлетворяет условиям: площадь от 100 кв. метров и больше на любой улице ИЛИ площадь от 80 кв. метров и больше, но на центральной улице Main Street.

Напишем функцию, проверяющую квартиру. Она принимает два аргумента: площадь (число) и название улицы (строку):

public static void main(String[] agrs) {
  System.out.print(isGoodApartment(91, "Queens Street")); // => false
  System.out.print(isGoodApartment(78, "Queens Street")); // => false
  System.out.print(isGoodApartment(70, "Main Street")); // => false

  System.out.print(isGoodApartment(120, "Queens Street")); // => true
  System.out.print(isGoodApartment(120, "Main Street")); // => true
  System.out.print(isGoodApartment(80, "Main Street")); // => true
}

public static boolean isGoodApartment(String area, String street) {
  return area >= 100 || (area >= 80 && "Main Street".equals(street));
}

Область математики, в которой изучаются логические операторы, называется булевой алгеброй. Ниже показаны «таблицы истинности» — по ним можно определить, каким будет результат применения оператора:

И &&

ABA && B
TRUETRUETRUE
TRUEFALSEFALSE
FALSETRUEFALSE
FALSEFALSEFALSE

ИЛИ ||

ABA || B
TRUETRUETRUE
TRUEFALSETRUE
FALSETRUETRUE
FALSEFALSEFALSE

Задание

Джон поручил Сэму реализовать автоматическое распознавание солдат Ланнистеров на видео. Идея автоматизировать дозор крепости казалась ему привлекательной. В процессе работы Сэму понадобилось написать функцию, которая определяет, Ланнистер ли перед ним или нет. Немного подумав, Сэм выделил следующие правила определения Ланнистера:


Если у солдата доспехи красного цвета И нет щита

ИЛИ

если у солдата есть щит с изображением льва

то это Ланнистер.


Напишите функцию isLannisterSoldier, которая принимает на вход два аргумента:

  1. Цвет доспехов (строка). Если доспехи красные, то строка red.
  2. null, если щита нет. Строка lion, если щит есть, и на нём изображен лев.

Функция возвращает true, если распознан Ланнистер, и false, если не распознан.


Нашли ошибку? Есть что добавить? Пулреквесты приветствуютсяhttps://github.com/hexlet-basics

Упражнение доступно только авторизованным пользователям.

Пожалуйста, авторизуйтесь с помощью учётной записи GitHub, это необходимо для отслеживания прогресса выполнения уроков. Если у вас ещё нет учётной записи, то сейчас самое время создать аккаунт на GitHub.