Regina 3.3
Версия реализации Regina языка программирования REXXВерсия интерпретатора Regina, выпущенная 13 марта 2003 года.
Примеры:
Hello, World! - REXX (334):
say 'Hello, World!'
Факториал - REXX (433):
В примере используется рекурсивное определение факториала.
REXX позволяет установить произвольную точность вычислений. В данном случае 14 знаков необходимо для того, чтобы все факториалы выводились как целые числа. Без первой строки факториалы, начиная с 13!, выводятся как числа с плавающей точкой.
Конкатенация строк может выполняться оператором || или в неявном виде при последовательном перечислении величин и констант. Если величины разделены пробелами, эти пробелы добавляются и в итоговую строку.
Слово procedure в определении функции необязательно; оно указывает на то, что переменные подпрограммы локальны; в противном случае они будут глобальными в пределах программы.
  numeric digits 14
  do n = 0 to 16
    say n"! = "factorial(n)
  end
exit
factorial: procedure
  parse arg n .
  if n = 0 then
    n = 1
  else
    n = n * factorial(n - 1)
  return n
Числа Фибоначчи - REXX (434):
В этом примере используется рекурсивное определение чисел Фибоначчи.
  numbers = ''
  do n = 1 to 16
    numbers = numbers||fibonacci(n)", "
  end
  say numbers"..."
exit
fibonacci: procedure
  parse arg n .
  if n < 3 then
    n = 1
  else
    n = fibonacci(n-1) + fibonacci(n-2)
  return n
Числа Фибоначчи - REXX (435):
В этом примере используется итеративное вычисление чисел Фибоначчи. Массивы реализованы как “корневые переменные”: обращение к элементам массива идет по их индексам fib.1 (или fib.first).
  fib.0 = 0
  fib.1 = 1
  output = fib.1||', '
  do f = 2 to 16
    e = f - 1; d = f - 2
    fib.f = fib.e + fib.d
    output = output||fib.f', '
  end
  say output"..."
exit

Комментарии
]]>blog comments powered by Disqus
]]>