Книга: Язык программирования Euphoria. Справочное руководство
2.2.4 Операции на рядах
2.2.4 Операции на рядах
Все операции (сравнения, логические и арифметические), описанные выше, равно как и математические подпрограммы, описанные в документе Часть II - Библиотека подпрограмм, могут быть применены к рядам и к отдельным числам (атомам).
Будучи применённой к ряду, унарная (для одного операнда) операция фактически применяется к каждому элементу ряда, и результирующий ряд имеет ту же самую длину. Если какой-то из элементов ряда сам по себе является рядом, это правило действует снова, рекурсивно, по отношению к каждому элементу вложенного ряда. То есть,
x = -{1, 2, 3, {4, 5}} -- x равно {-1, -2, -3, {-4, -5}}
Если бинарная (для двух операндов) операция применяется по отношению к операндам, каждый из которых является рядом, то эти два ряда должны иметь одинаковую длину. Если условие одинаковости длины рядов выполнено, бинарная операция производится над соответствующими элементами рядов, взятыми из этих двух рядов для формирования результирующего ряда. То есть,
x = {5, 6, 7, 8} + {10, 10, 20, 100}
-- x равно {15, 16, 27, 108}
Если в бинарной операции участвуют два операнда, один из которых является рядом, а второй - единственным числом (атомом), этот атом эффективно повторяется для формирования ряда с длиной, равной длине первого операнда. Затем применяются правила, действующие в отношении двух рядов. Некоторые примеры:
y = {4, 5, 6}
w = 5 * y -- w равно {20, 25, 30}
x = {1, 2, 3}
z = x + y -- z равно {5, 7, 9}
z = x < y -- z равно {1, 1, 1}
w = {{1, 2}, {3, 4}, {5}}
w = w * y -- w равно {{4, 8}, {15, 20}, {30}}
w = {1, 0, 0, 1} and {1, 1, 1, 0} -- w равно {1, 0, 0, 0}
w = not {1, 5, -2, 0, 0} -- w равно {0, 0, 0, 1, 1}
w = {1, 2, 3} = {1, 2, 4} -- w равно {1, 1, 0}
-- обратите внимание, что первый символ '=' - это команда присваивания,
-- а второй символ '=' - это оператор сравнения, проверяющий равенство
-- соответствующих элементов рядов попарно с формированием ряда результатов
-- сравнения, полученных для каждой из пар элементов
Примечание: В вопросе сравнения рядов Euphoria имеется одна не вполне и не сразу заметная тонкость. Когда вы хотите сравнить две строки (или два других ряда), здесь, в отличие от некоторых других языков, не следует использовать оператор '=':
if "APPLE" = "ORANGE" then -- ОШИБКА!
В выражении, стоящем после команды "if" (если), символ '=' трактуется как бинарный оператор (сравнения), подобно другим бинарным операторам вроде '+', '*' и т.д., следовательно, он применяется к соответствующим парам элементов рядов, и эти ряды должны иметь одинаковую длину. Когда условие равенства длин операндов соблюдено, формируется ряд результатов сравнения, состоящий из нулей и единиц, но когда длины не равны, вы получите сообщение об ошибке в вашей программе. С другой стороны, команда "if" ожидает результат вычисления выражения, подаваемого в эту команду, в виде атома, а не ряда, то есть, и при равенстве длин рядов вы получите сообщение об ошибке в вашей программе. Для получения результата сравнения рядов в виде интегральной (число), а не поэлементной (ряд), характеристики, необходимо использовать встроенную функцию equal() (равно):
if equal("APPLE", "ORANGE") then -- ПРАВИЛЬНО
В общем-то, для несколько более полного сравнения рядов имеется ещё и встроенная функция compare() (сравнить):
if compare("APPLE", "ORANGE") = 0 then -- ПРАВИЛЬНО
Вы можете использовать compare() также и для других сравнений:
if compare("APPLE", "ORANGE") < 0 then -- ПРАВИЛЬНО
-- здесь "APPLE" меньше чем "ORANGE",
-- так как длина второго ряда больше (истина, 1)
- 2.2.3 Арифметические операции
- 2.2.1 Операции сравнения
- 2.2.2 Логические операции
- 2.2.9 Другие операции на рядах
- Что делать, если при установке принтера появляется сообщение Невозможно завершение операции. Подсистема печати недоступн...
- Операции с множествами узлов
- 4. Null-значения и логические операции
- 1. Операции объединения, пересечения, разности
- 2. Операции декартового произведения и естественного соединения
- 5. Производные операции
- 2. Унарные операции на языке структурированных запросов
- 3. Бинарные операции на языке структурированных запросов