Читаем Учебник по Haskell полностью

Инфиксная

add a b

a ‘add‘ b

(+) a b

a + b

Также мы научились приводить одни численные типы к другим и пользоваться документацией.

2.9 Упражнения

• Напишите функцию beside :: Nat -> Nat -> Bool, которая будет возвращать True только в том случае,

если два аргумента находятся рядом, то есть один из них можно получить через другой операцией Succ.

• Напишите функцию beside2 :: Nat -> Nat -> Bool, которая будет возвращать True только если

аргументы являются соседями через некоторое другое число.

• Мы написали очень неэффективную функцию сложения натуральных чисел. Проблема в том, что число

рекурсивных вызовов функции зависит от величины второго аргумента. Если мы захотим прибавить

единицу к сотне, то порядок следования аргументов существенно повлияет на скорость вычисления.

Напишите функцию, которая лишена этого недостатка.

• Напишите функцию возведения в степень pow :: Nat -> Nat -> Nat.

• Напишите тип, описывающий бинарные деревья BinTree a. Бинарное дерево может быть либо листом

со значением типа a, либо хранить два поддерева.

• Напишите функцию reverse :: BinTree a -> BinTree a, которая переворачивает дерево. Она меняет

местами два элемента в узле дерева.

• Напишите функцию depth :: BinTree a -> Nat, которая вычисляет глубину дерева, то есть самый

длинный путь от корня дерева к листу.

38 | Глава 2: Первая программа

• Напишите функцию leaves :: BinTree a -> [a], которая переводит бинарное дерево в список, воз-

вращая все элементы в листьях дерева.

• Обратите внимание на раздел List Operations в Prelude. Посмотрите на функции и их типы. Попро-

буйте догадаться по типу функции и названию что она делает.

• Попробуйте разобраться по документации с классами Ord (сравнение на больше/меньше), Enum (пере-

числения) и Integral (целые числа). Также стоит отметить класс Floating. Если у вас не получится,

не беда, они обязательно встретятся нам вновь. Там и разберёмся.

• Найдите функцию, которая переставляет элементы пары местами (элементы могут быть разных типов).

Потренируйтесь с кортежами. Определите аналоги функций fst и snd для не пар. Обратите внимание

на то, что сочетание символов (,) это функция-конструктор пары:

Prelude> (,) ”Hi” 101

(”Hi”,101)

Prelude> :t (,)

(,) :: a -> b -> (a, b)

Также определены („), („,) и другие.

Упражнения | 39

Глава 3

Типы

С помощью типов мы определяем все возможные значения в нашей программе. Мы определяем основные

примитивы и способы их комбинирования. Например в типе Nat:

data Nat = Zero | Succ Nat

Один конструктор-примитив Zero, и один конструктор Succ, с помощью которого мы можем делать со-

ставные значения. Определив тип Nat таким образом, мы говорим, что значения типа Nat могут быть только

такими:

Zero,

Succ Zero,

Succ (Succ Zero), Succ (Succ (Succ Zero)), ...

Все значения являются цепочками Succ с Zero на конце. Если где-нибудь мы попытаемся построить значе-

ние, которое не соответствует нашему типу, мы получим ошибку компиляции, то есть программа не пройдёт

проверку типов. Так типы описывают множество допустимых значений.

Значения, которые проходят проверку типов мы будем называть допустимыми, а те, которые не проходят

соответственно недопустимыми. Так например следующие значения недопустимы для Nat

Succ Zero Zero,

Succ Succ, True, Zero (Zero Succ), ...

Недопустимых значений конечно гораздо больше. Такое проявляется и в естественном языке, бессмыс-

ленных комбинаций слов гораздо больше, чем осмысленных предложений. Обратите внимание на то, что мы

говорим о значениях (не)допустимых для некоторого типа, например значение True допустимо для Bool, но

недопустимо для Nat.

Сами типы строятся не произвольным образом. Мы узнали, что при их построении используются две ос-

новные операции, это сумма и произведение типов. Это говорит о том, что в типах должны быть какие-то

закономерности, которые распространяются на все значения. В этой главе мы посмотрим на эти закономер-

ности.

3.1 Структура алгебраических типов данных

Итак у нас лишь две операции: сумма и произведение. Давайте для начала рассмотрим два крайних

случая.

• Только произведение типов

data T = Name T1 T2 ... TN

Мы говорим, что значение нашего нового типа T состоит из значений типов T1, T2, … , TN и у нас есть

лишь один способ составить значение этого типа. Единственное, что мы можем сделать это применить

к значениям типов Ti конструктор Name.

Пример:

data Time = Time Hour Second Minute

• Только сумма типов

data T = Name1 | Name2 | ... | NameN

40 | Глава 3: Типы

Мы говорим, что у нашего нового типа T может быть лишь несколько значений, и перечисляем их в

альтернативах через знак |.

Пример:

data Bool = True | False

Перейти на страницу:

Похожие книги

1С: Бухгалтерия 8 с нуля
1С: Бухгалтерия 8 с нуля

Книга содержит полное описание приемов и методов работы с программой 1С:Бухгалтерия 8. Рассматривается автоматизация всех основных участков бухгалтерии: учет наличных и безналичных денежных средств, основных средств и НМА, прихода и расхода товарно-материальных ценностей, зарплаты, производства. Описано, как вводить исходные данные, заполнять справочники и каталоги, работать с первичными документами, проводить их по учету, формировать разнообразные отчеты, выводить данные на печать, настраивать программу и использовать ее сервисные функции. Каждый урок содержит подробное описание рассматриваемой темы с детальным разбором и иллюстрированием всех этапов.Для широкого круга пользователей.

Алексей Анатольевич Гладкий

Программирование, программы, базы данных / Программное обеспечение / Бухучет и аудит / Финансы и бизнес / Книги по IT / Словари и Энциклопедии
1С: Управление торговлей 8.2
1С: Управление торговлей 8.2

Современные торговые предприятия предлагают своим клиентам широчайший ассортимент товаров, который исчисляется тысячами и десятками тысяч наименований. Причем многие позиции могут реализовываться на разных условиях: предоплата, отсрочка платежи, скидка, наценка, объем партии, и т.д. Клиенты зачастую делятся на категории – VIP-клиент, обычный клиент, постоянный клиент, мелкооптовый клиент, и т.д. Товарные позиции могут комплектоваться и разукомплектовываться, многие товары подлежат обязательной сертификации и гигиеническим исследованиям, некондиционные позиции необходимо списывать, на складах периодически должна проводиться инвентаризация, каждая компания должна иметь свою маркетинговую политику и т.д., вообщем – современное торговое предприятие представляет живой организм, находящийся в постоянном движении.Очевидно, что вся эта кипучая деятельность требует автоматизации. Для решения этой задачи существуют специальные программные средства, и в этой книге мы познакомим вам с самым популярным продуктом, предназначенным для автоматизации деятельности торгового предприятия – «1С Управление торговлей», которое реализовано на новейшей технологической платформе версии 1С 8.2.

Алексей Анатольевич Гладкий

Финансы / Программирование, программы, базы данных