На правах рукописи ГИНДУЛЛИН Рамиз Вилевич

реклама
На правах рукописи
ГИНДУЛЛИН Рамиз Вилевич
ОПТИМИЗАЦИЯ МАРШРУТА ДОСТАВКИ ОДНОРОДНОГО
ГРУЗА ОТ МНОЖЕСТВА ПРОИЗВОДИТЕЛЕЙ
МНОЖЕСТВУ ПОТРЕБИТЕЛЕЙ
Специальность 05.13.01 – Системный анализ, управление
и обработка информации (в промышленности)
Диссертация
на соискание ученой степени
кандидата физико-математических наук
Научный руководитель д.ф-м.н., профессор Бронштейн Е.М.
Уфа 2013
ОГЛАВЛЕНИЕ
С.
Введение……………………………………………………………………….. 3
1
ОБЗОР ЗАДАЧ ТРАНСПОРТНОЙ МАРШРУТИЗАЦИИ................... 9
1.1
Задачи транспортной маршрутизации.................................................. 9
1.2
Методы решения задач транспортной маршрутизации...................... 21
1.3
Задача коммивояжера (TSP, Traveling salesman problem)................... 24
1.4
Выводы ..................................................................................................... 33
2
МАТЕМАТИЧЕСКАЯ МОДЕЛЬ МОНОНОМЕНКЛАТУРНОЙ
ОПТИМИЗАЦИОННОЙ ЗАДАЧИ МАРШРУТИЗАЦИИ
ТРАНСПОРТНЫХ СРЕДСТВ................................................................ 34
2.1
Задача 1.................................................................................................... 34
2.2
Задача 2.................................................................................................... 37
2.3
Задача 3.................................................................................................... 45
2.4
Задача 4.................................................................................................... 52
3
ПОСТАНОВКА ЧИСЛЕННЫХ ЭКСПЕРИМЕНТОВ,
ИССЛЕДОВАНИЕ РЕЗУЛЬТАТОВ...................................................... 56
3.1
Точные решения задачи 2...................................................................... 56
3.2
Зависимость длины оптимального маршрута от вместимости
транспортного средства......................................................................... 58
3.3
Сравнение эффективности эвристик для решения задачи 2.............
3.4
Сравнение эффективности эвристик для решения задачи 3.............. 65
3.5
Сравнение эффективности жадных алгоритмов для решения
60
задачи 3..................................................................................................... 68
ЗАКЛЮЧЕНИЕ .................................................................................................. 72
СПИСОК ИСПОЛЬЗОВАННОЙ ЛИТЕРАТУРЫ........................................... 74
ПРИЛОЖЕНИЕ А……………………………………………………………... 93
2
ВВЕДЕНИЕ
Актуальность
темы
работы.
Транспортная
промышленность
необходима для обеспечения производства сырьем и доставки готового
товара потребителям. Особое внимание уделяется задачам, связанным с
планированием маршрутов. По разным оценкам от 30% до 50 % всех затрат
на логистику связано с транспортными издержками.
Формирование рациональных маршрутов при строгом соблюдении
сроков поставок помогает добиться не только минимизации затрат на
эксплуатацию,
на
перевозку
людей,
но
и
сократить
товарно-
производственные запасы на складах.
Задачам
в
области
формирования
оптимальных
транспортных
маршрутов посвящены многочисленные исследования в разных странах
мира. Особую актуальность приобретают работы, позволяющие точно
вычислять
объемы
грузоперевозок,
рассчитывать
количество
единиц
транспорта, необходимых для обеспечения грузопотоков, определять
рациональные маршруты движения, а также сократить суммарные затраты на
транспортировку. Эти обстоятельства подтверждают актуальность темы
диссертации.
Степень
рассматривается
разработанности
разновидность
темы
задачи
исследования.
маршрутизации
В
работе
транспортных
средств при перевозке грузов – VRP (Vehicle Routing Problem) – SVRPPD –
задача транспортной маршрутизации с вывозом и доставкой одним
транспортным средством. Первая задача транспортной маршрутизации была
сформулирована Г. Данцигом и Дж. Рамсером в 1959 году, ее постановка
инициировала
важный
класс
задач
оптимизации.
Наиболее
часто
встречающиеся постановки задач данного класса предполагают доставку
однородных грузов из пункта производства или склада потребителям.
Предполагается,
что
целью
является
минимизация
стоимости
транспортировки. Встречаются задачи и с другой целевой функцией
3
(например, временем доставки грузов), но их, как правило, можно
переформулировать таким образом, что целевая функция будет носить
экономический смысл Как правило, задачи данного класса относятся к NPтрудным, точное решение которых при сколько-нибудь значительной
размерности требует огромного количества времени. На сегодняшний день
сформулировано
множество
вариантов
данной
задачи,
в
которых
учитываются различные реальные ограничения, разработан ряд алгоритмов
приближенного поиска оптимальных решений. Это связано с тем, что
развитие логистических процессов и потребность в учете новых факторов
ведут к постановке новых задач, требующих, в свою очередь, применения
новых методов решения. Создана европейская рабочая группа VeRoLog
(Vehicle Routing and Logistics), которая активно занимается задачами
транспортной маршрутизации.
Необходимо указать на отличие задачи в рассматриваемой постановке
от
классической
задачи
маршрутизации
транспортных
средств.
Особенностями рассматриваемой задачи являются наличие множественных
пунктов-производителей,
из
которых
производится
вывоз
груза.
Поставленная задача может быть сформулирована, как целочисленная
линейная оптимизационная задача, и является обобщением двух известных
задач: задачи коммивояжера и задачи о загрузке рюкзака. Менее 10% работ,
посвященных задачам транспортной маршрутизации, рассматривают данный
вариант задачи. Результаты по близким задачам получены Cordeau J.-F. [51],
Laporte G. [61, 173], Renaud J. [173], Desrosiers J. [67], Mingozzi A. [41],
Pankratz G. [163], Ченцовым А.Г. [16], Гимади Э.Х. [11] и другими учѐными.
Также, создана европейская рабочая группа VeRoLog (Vehicle Routing and
Logistics),
которая
активно
занимается
задачами
транспортной
маршрутизации.
Область исследования. Задачи организации транспортировки грузов.
4
Цель работы. Исследование и разработка эффективных методов
решения монономенклатурных оптимизационных задач маршрутизации
транспортных средств с ограничениями на перевозку.
Задачи исследования. Для достижения цели работы были поставлены
и решены следующие задачи:
1. Формализация
оптимизационных
задач
монономенклатурной
маршрутизации с одним транспортным средством и несколькими пунктами
производства и потребления.
2. Разработка точных алгоритмов решения поставленных задач
маршрутизации, в том числе в целочисленном варианте.
3. Разработка эвристических алгоритмов решения поставленных задач
маршрутизации.
4. Реализация разработанных методов на ЭВМ, экспериментальная
проверка эффективности работы предложенных алгоритмов.
Методы
математического
исследования.
В
работе
программирования,
теории
применяются
графов,
методы
комбинаторной
оптимизации, формализация, алгоритмизация, моделирование и эксперимент.
Информационная база исследования включает сгенерированные
псевдослучайным образом по равномерному закону распределения данные о
пунктах производства и потребления, включая их координаты.
На защиту выносятся следующие результаты исследований:
1. Математические
модели
оптимизационных
задач
семейства
монономенклатурной маршрутизации транспортных средств с одним
транспортным средством и забором и доставкой грузов при различных
ограничениях.
2. Точные
и
эвристические
алгоритмы
построения
решения
оптимизационных задач семейства монономенклатурной маршрутизации
транспортных средств с одним транспортным средством и забором и
доставкой грузов.
3. Сравнение эффективности предложенных алгоритмов.
5
Научная новизна. Получены следующие основные результаты,
обладающие научной новизной:
1. Формализация поставленных задач (в том числе в виде задач
целочисленного
линейного
программирования
и
программирования,
линейного
булева
булева
квадратичного
программирования)
оптимизационных задач маршрутизации транспортных средств, в которых
производится вывоз груза от множества производителей к множеству
потребителей (п. 2 паспорта специальности 05.13.01). Исследование данных
моделей позволило получить оценки минимальной допустимой вместимости
транспортного средства в случае, когда транспортное средство может
посетить каждый пункт один раз.
2. Доказательство того, что для любого допустимого способа
перевозки грузов по некоторому маршруту при целых исходных данных
задачи, существует способ перевозки по тому же маршруту, в котором все
веса загружаемого и выгружаемого груза являются целыми. Существование
загрузки транспортных средств грузами с целочисленными весами позволило
разработать точный алгоритм локальной оптимизации для целочисленного
случая задачи (п. 3 паспорта специальности 05.13.01).
3. Методы
и
алгоритмы
решения
задачи
маршрутизации
транспортных средств с учетом различных ограничений. Разработаны и
программно реализованы эвристические алгоритмы решения задачи (п. 5
паспорта специальности 05.13.01).
4. Проведены серии вычислительных экспериментов для оценки
эффективности
предложенных
алгоритмов.
Эмпирически
получена
зависимость длины оптимального маршрута от вместимости транспортного
средства.
Практическая
и
теоретическая
значимость.
Теоретическая
значимость заключается в формализации и решении монономенклатурной
оптимизационной задачи маршрутизации транспортных средств с одним
транспортным
средством
c
несколькими
пунктами
производства
и
6
потребления с возможностью раздельных доставок и использования складов,
относящейся к классу VRP. Предложенные методы и алгоритмы могут
применяться для решения родственных задач организации транспортировки
грузов.
Практическую ценность работы составляет определение наименьшей
допустимой вместимости транспортного средства и плана перевозок с
минимальными затратами на транспортировку при заданной вместимости
транспортного средства. Это делает возможным применение разработанных
методов построения кратчайшего маршрута задачи и, как следствие,
применение
их
программной
транспортно-логистических
обеспечение,
задач
на
в
рамках
разработанное
зарегистрировано
реализации
Федеральной
для
решения
производстве.
Программное
диссертационной
службой
по
реальных
работы,
интеллектуальной
собственности, патентам и товарным знакам, свидетельство № 2011615572
«Решение задач транспортной маршрутизации различными методами».
Степень достоверности и апробация результатов.
-Теоретические положения работы подтверждаются математическими
доказательствами.
-Адекватность предложенных моделей подтверждается получением
совпадающих результатов при использований различных подходов и
формализаций на широком классе примеров.
Апробация работы. Основные результаты диссертационной работы
докладывались и обсуждались на:
1.
Всероссийская зимняя школа Всероссийская зимняя школа-
семинар аспирантов и молодых ученых семинар аспирантов и молодых
ученых семинар аспирантов и молодых ученых «Актуальные проблемы
науки и техники», Уфа, 2010.
2.
Всероссийская
конференция
«Математическое
программирование и приложения», Екатеринбург, ИММ УрО РАН, 2011.
7
3.
Международная
научная
конференции
"Математическое
моделирование, оптимизация и информационные технологии", Кишинеу,
2012.
4.
Международная
конференция
«Дискретная
оптимизация
и
исследование операций», Новосибирск, 2013.
5.
Вторая ежегодная конференция Европейской рабочей группы
VeRoLog, Саутгемптон, 2013.
6.
Научные семинары в Уфимском государственном авиационном
техническом университете, в Башкирском государственном университете и
Институте математики Уфимского научного центра РАН.
Работа выполнена при поддержке РФФИ (проекты № 10-06-00001 и №
13-01-00005).
8
1.
ОБЗОР ЗАДАЧ ТРАНСПОРТНОЙ МАРШРУТИЗАЦИИ
1.1 Задачи транспортной маршрутизации
Задачи маршрутизации являются одним из наиболее важных классов
задач транспортной логистики. Целью данных задач является минимизация
стоимости, расстояния или времени транспортировки грузов.
История задач маршрутизации насчитывает более полувека. Первая
работа, посвященная данному типу задач, появилась в 1959 году, когда была
опубликована статья Г. Данцига и Дж. Рамсера [65], в которой была
сформулирована группа задач, впоследствии названная VRP – Vehicle
Routing Problem. В данной работе рассматривалась задача нахождения
оптимального маршрута доставки парком бензовозов продукта от конечной
станции
магистрального
обслуживающих
Используя
трубопровода
терминалов
методы,
(задача
опирающиеся
до
большого
диспетчеризации
на
формулировки
количества
грузовиков).
линейного
программирования, предложенные ручные вычисления давали решение,
близкое к оптимальному, для задач с количеством маршрутов 4 и
количеством станции 12. Типичная постановка задачи приведена на рисунке
1.1.
9
Рисунок 1.1 Типичная постановка задачи транспортной маршрутизации и ее
решение.
Задачи транспортной маршрутизации являются обобщением задачи
коммивояжера, поэтому, как правило, относятся к классу NP-сложных задач
(однако,
некоторые
частные
варианты
задачи
могут
решаться
за
полиномиальное время, например, [21]).
На
текущий
момент,
имеется
множество
вариантов
задач
маршрутизации [38, 164, 165, 8]. В целом, задачи маршрутизации можно
разделить по следующим характеристикам [8]:
1. Пункты производства
a) Пункт производства один. Это характерно для ситуации, когда
имеется склад (база) с которого осуществляются поставки различным
потребителям.
б) Пунктов несколько. Такая ситуация чаще всего возникает, если
грузы перевозятся от нескольких производителей к потребителям. Еще один
пример - перевозка пассажиров (например, при организации работы
10
таксопарка) В этом случае пункт посадки каждого пассажира можно считать
пунктом производства.
2. Пункты потребления.
а) Пункт один. В частности это так, если продукция из разных
мест должна доставляться на склад или в пункт сертификации.
б) пунктов несколько Эта ситуация наиболее распространенная.
Содержательная интерпретация аналогична 1б.
3) Сеть дорог.
а) Дорога характеризуется одним параметром.
б) Дорога характеризуется несколькими параметрами (стоимость
перевозки,
расстояние,
пропускная
способность
по
весу,
габариты,
ограничения по скорости и др.).
-Все учитываемые характеристики аддитивно зависят от
пути.
-Среди
характеристик
есть
неаддитивные
(например,
пропускная способность).
4) Количество груза.
а) Количество груза характеризуется вещественным числом
(непрерывная задача).
-Одним.
-Несколькими.
б) Количество груза характеризуется целым числом (дискретная
задача).
-Одним.
-Несколькими.
5) Базы ТС (депо).
а) База одна.
б) Баз несколько.
в) Базы совпадают с пунктами производства.
6) Вид груза.
11
а) Задачи с однородным грузом.
б) Многопродуктовые задачи.
7) Характер ТС.
а) ТС единственное.
б) Все ТС одинаковые.
в) ТС различны.
8) Ограничения на вместимость ТС.
а) Предусмотрены ограничения только по одному параметру.
б) Предусмотрены ограничения по нескольким параметрам.
9) Ограничения по видам перевозимых грузов.
а) Есть грузы, запрещенные к перевозке тем или иным ТС.
б) Для каждого ТС есть ограничения по различным видам
перевозимых грузов.
в) Существуют запреты на совместную перевозку грузов
некоторых видов одним ТС.
10) Условия перевозки.
а) При перевозке груза из каждого пункта производства в каждый
пункт
потребления
может использоваться
одно
ТС независимо
от
перевозимого груза.
б) При перевозке груза из каждого пункта производства одно ТС
может развозить грузы в различные пункты потребления.
в) В каждый пункт потребления грузы из разных пунктов
производства доставляет одно ТС.
г) ТС могут собирать груз в различных пунктах производства и
перевозить в различные пункты потребления.
д)
Возможность
совпадения
пунктов
производства
и
потребления.
-Некоторые пункты могут быть одновременно пунктами
производства и потребления.
-Все пункты разные.
12
11) Ограничения по времени.
а) Грузы из пунктов производства должны забираться в
указанные временные окна.
б) Грузы в пункты потребления должны доставляться в
указанные временные окна.
в) Максимальная длительность маршрута перевозок ограничена.
г) Время непрерывного пребывания ТС в пути ограничено.
д) Имеются те или иные ограничения на последовательность
перевозок.
12) Особые условия перевозки.
а) Каждый вид груза должен быть доставлен из некоторого
пункта производства в некоторый пункт потребления (такси).
б) Не допускается порожний пробег (кроме начального и
конечного отрезков маршрута).
13) Факторы, определяющие стоимость перевозки.
а) Зависимость стоимости перевозки только от самого пути.
б) Зависимость стоимости перевозки от загрузки ТС.
-Пропорциональность зависимости стоимости от загрузки.
14) Условие возврата.
а) ТС должны возвращаться на исходную базу.
б) ТС должны завершать маршрут на какой-нибудь базе.
в) ТС могут завершать маршрут в любом месте.
15) Учет упаковки в транспортное средство (для дискретного случая
постановки задачи). При этом условии в задачу вводятся ограничения
на размещение ящиков внутри транспортного средства, а также ограничение
на последовательность погрузки-выгрузки груза / стековый принцип (LIFO).
16) Определенность.
а) Статическая задача, т.е. заказы в процессе доставки не
изменяются.
б) Динамическая задача, т.е. заказы после планирования могут
13
добавляться или отменяться.
Наиболее
исследованными
вариантами
задач
маршрутизации
являются:
Capacitated VRP (CVRP, задача маршрутизации транспортных средств
с
учетом
грузоподъемности).
Базовый
вариант
задач
транспортной
маршрутизации, который и был описан в работе Данцига и Рамсера. Парк
транспортных средств одинаковой вместимости находятся в одном депо.
Задача состоит в нахождении минимальных по затратам (денежным, времени
или расстоянию) замкнутых маршрутов, которые полностью обслужат всех
клиентов, таких чтобы выполнялось условие не превышения вместимости ТС
на каждом из маршрутов. При этом, каждый потребитель обсуживается ТС
только один раз, поэтому вместимость ТС должна превышать потребность
любого из клиентов. Кристофидесом в 1979 году была дана формализация в
виде задачи линейного программирования [58].
Multi Depot VRP (задача транспортной маршрутизации с множеством
депо). У компании может быть несколько депо, через которые можно
обслуживать потребителей. Если клиенты сгруппированы около депо, то
данная задача маршрутизации может быть решена как, множество
независимых задач маршрутизации. Однако, если клиенты и депо смешаны
между собой, то в данном случае решается задача MDVRP. Одним из ранних
упоминаний задачи с несколькими депо является [204].
Periodic VRP (периодическая задача маршрутизации). Обобщение
классической задачи маршрутизации, в которой период планирования
составляет более одного дня. У каждого клиента возникает ежедневная
потребность, которая должна быть удовлетворена как минимум одним
визитом ТС. Впервые рассмотрена в [56].
14
VRP with Backhauls (задача транспортной маршрутизации с обратным
транзитом). В данной задаче надо учитывать возможность того, что
потребители могут вернуть часть ранее завезенного груза, который
транспортное средство должно будет отвезти на склад. Главным допущением
в данной задаче считается то, что перед тем как с пункта можно будет
забрать груз, в него уже был завезен груз на предыдущих шагах данного
маршрута или предыдущих развозках. При этом, заранее известны
количества груза, которые надо будет завезти и забрать. Данная постановка
задачи означает, что в отличие от предыдущих задач, полная или почти
полная загрузка транспортных средств грузом в депо не является
экономически выгодной или, более того, осуществимым. Впервые термин
VRPB был представлен в [98]. Существует 3 группы задач с обратным
транзитом [45]:
- транспортное средство может забирать груз на маршруте до того как
полностью развезет свои доставки;
- транспортное средство может забирать груз на маршруте до того как
полностью развезет свои доставки и один и тот же клиент может как
принимать груз, так и отправлять;
- транспортное средство на маршруте вначале доставляет груз до
клиентов, и только потом забирает его; маршрут может состоять только из
доставок, но не может состоять только из забора груза.
Первые два класса задач впервые поставлены и рассмотрены в [52] и
[102]. Однако эти типы задач в литературе рассматривались реже в связи с
тем, что на практике сложно переставлять товары в частично заполненном
транспортном средстве. Третий тип задач в литературе встречается чаще.
Ранними работами, посвященными ему, являются [66], [98] и [99].
VRP with Pick-Up and Delivering (задача транспортной маршрутизации
с вывозом и доставками, VRPPD). Задача является обобщением предыдущего
класса задач. Главная особенность заключается в том, что отсутствует
15
необходимость посещения клиента с целью передать ему груз, чтобы
впоследствии вернуться и осуществить обратный транзит. То есть, у клиента
изначально имеется груз, который необходимо забрать. В результате, клиент
у которого имеется груз для вывоза и который должен принять груз может
быть посещен транспортным средством дважды. Возможность передачи
груза от одного клиента к другому допускается, но этот случай мало
исследован [103]. Согласно [93] менее 10% работ, посвященных задачам
транспортной маршрутизации, рассматривают варианты задач с вывозом и
доставками. Вариант задачи с одним ТС имеет несколько названий [106]:
SVRPPD, 1-VRPPD [67, 143], SVPDP [61], SPDP [166], TSPPD [51].
Подобного типа задачи появляются при перевозках однородных грузов,
таких как газ, почва, песок, деньги.
Для VRPPD с множеством ТС в [159] рассмотрено использование
раздельных доставок и загрузок (то есть, с возможностью неоднократного
посещения пунктов). Было показано, что использование раздельных доставок
позволяет сократить расстояние перевозок, по сравнению с однократным
посещением клиентов. Размер экономии сильно зависит от вместимости ТС
по сравнению с запросами пунктов.
Вариантом данной задачи можно считать VRP with Satellite Facilities
(задача транспортной маршрутизации с сопутствующими складами), в
которой у транспортного средства есть возможность пополнить груз в
сопутствующих складах, без возврата в депо [118].
VRP with Time Windows (задача транспортной маршрутизации с
временными окнами). К задаче транспортной маршрутизации добавляются
ограничения на время посещения каждого из клиентов. Клиент может быть
обслужен только в пределах заданного временного окна. [187]
16
Stochastic VRP (стохастическая задача транспортной маршрутизации).
Это задача маршрутизации у которой не менее одного параметра заданы
случайным образом. Возможно три варианта задачи:
- стохастические потребители (потребитель может присутствовать с
заданной вероятностью);
- стохастические потребности клиентов;
- стохастическое время обслуживания.
В связи с элементом случайности уже невозможно требовать
выполнения всех ограничений. В результате, лицо принимающее решение
может требовать или выполнение ограничений с определенной вероятностью
(то есть, рассматривается средний случай), или встроить в модель действия
по корректировке в случае необходимости.
Первый случай известен, как Chance Costrained Programming (CCP,
программирование с вероятностными ограничениями) и он сравнительно
легко решается, когда его сводят к детерминированному варианту задачи
маршрутизации. [55, 128, 129].
Второй вариант SVRP может решаться как Stochastic program with
Recource (SPR, стохастическое программирование с рекурсией). Начальное
решение определяется до получения значений случайных величин. На
следующем этапе уже могут приниматься корректирующие действия. [40,
115, 189].
Split Deliveries VRP (SDVRP, задача транспортной маршрутизации с
раздельными доставками). В данной задаче, парк однотипных транспортных
средств с ограниченной вместимостью должен обслужить некоторое
множество потребителей. Каждый потребитель может быть посещен более
одного раза, в отличие от задачи VRP, в связи с этим потребность отдельного
потребителя может быть выше вместимости транспортного средства. Каждое
ТС должно начинать и заканчивать свой маршрут в депо. Задача состоит в
нахождении множества маршрутов транспортных средств, которые обслужат
17
всех потребителей, таким образом, чтобы не было нарушено условие
вместимости транспортных средств и с минимальной общей длиной
маршрутов.
Задача была представлена в литературе 20 лет назад в [74] и [75], в
которых было показано, что использование раздельных доставок в некоторых
случаях позволяет получить маршрут короче, чем в случае однократного
посещения клиентов. В [24], анализируется максимально возможный
выигрыш, получаемый при использовании раздельных доставок, а в [23] те
же авторы представили результаты вычислительных экспериментов, в
которых показано, как данный выигрыш зависит от характеристик задачи. В
[21] они анализируют вычислительную сложность SDVRP. Было выявлено,
что в случае целочисленного варианта с вместимостью транспортных средств
не более 2, задачу можно свести к задаче b-согласования вершин графа (bmatching problem), постановки которой приведены в [91], и для которой
имеется полиномиальный алгоритм решения [91, 107]. В остальных случаях,
SDVRP относится к классу NP-полных задач.
Dror, Laporte и Trudeau [73] предложили метод ветвей и границ,
основанный на целочисленной линейной постановке SDVRP, куда помимо
прочих неравенств были включены неравенства связности, которые
обеспечивали то, что каждый клиент будет обслужен хотя бы одним
транспортным средством. Метод был опробован на трех небольших
примерах до 20 пунктов с различным спросом со стороны потребителей.
Belenguer, Martinez и Mota рассматривали SDVRP как полиэдр [35]. На
основании частичного описания SDVRP-полиэдра, авторы использовали
метод ветвей и отсечений, который позволял решать задачи средних
размеров с количеством потребителей до 51. Усиленная линейная релаксация
позволяет получить хорошую нижнюю границу для значения оптимального
решения.
Точные способы решения задачи также были предложены Li et al [132],
Джин, Лиу и Боуден [117, 136]. Оба подхода работают только при очень
18
маленьких размерностях. Лучший результат получен для SDVRP с
временными окнами (SDVRPTW) в работе Gueguen [90, 105]. В последней
работе предложены точные методы, способные решать задачу с сотней
потребителей.
Первым эвристическим алгоритмом для SDVRP стал локальный поиск,
который был предложен в работах Dror и Trudeau [74, 75]. Предлагалось
использование двухэтапной процедуры, по которой вначале получали
допустимое решение задачи VRP, а затем его улучшали, используя
добавление путей и обмен пунктами между ними. Добавление путей
означает, что создавался новый путь, который обслуживал клиента
раздельной доставкой, если это позволяло уменьшить общую длину
перемещений. Обмен пунктами состоял в том, что рассматривался клиент i с
потребностью di и его убирали со всех путей, которые его обслуживают.
Далее, рассматриваются все пути, в которых транспортное средство
нагружено не полностью и данное транспортное средство имеет возможность
обслужить еще и пункт i. Производится расчет того, насколько длиннее
станет общая дистанция, если клиента i поместить в каждый из данных
путей. Выбирается то подмножество вставок, общая дистанция при котором
является минимальной. Данные простые подходы успешно использовались в
эвристических и метаэвристических методах в будущем.
Позднее, предложено использование табуированного поиска [20, 22]. В
[55] предложен эвристический частично целочисленный алгоритм пути
"между записями", который оказался эффективным в задачах с большими
потребностями
со
стороны
пунктов-потребителей.
Вычислительные
эксперименты, сравнивающие эффективность этих методов приведены в
[202]. Frizzel и Giffin в [84] представили формализацию задачи SDVRP с
сеткой и временными окнами (SDVRP with grid network and time windows).
Применение SDVRP на практике рассмотрено в работе Mullaseril, Dror
и Leung [157], в которой представлена задача управления парком грузовиков,
развозящих еду для крупного ранчо. Необходимо было ежедневное
19
обеспечение питания порядка 100 тыс. голов крупного рогатого скота в
пределах заданных временных окон шестью грузовиками. Данная задача
была формализована, как задача о китайском почтальоне с ограниченной
вместимостью,
раздельными
доставками
и
временными
окнами.
Вычислительный эксперимент показал, что использование раздельных
доставок позволяет значительно сократить общую пройденную дистанцию в
большей части вычислительных экспериментов.
В [186] рассмотрена задача о расписании полетов вертолетов к
платформам в прибрежной зоне Северного моря для перемещения рабочих
между сменами. Вертолеты могли перевозить определенное максимальное
число рабочих и, в связи с ограничениями на топливо, не могли пролетать
большие расстояния. Данная задача была сформулирована, как SDVRP.
В [25] Archetti и Speranza представили широкий обзор задач, в которых
запросы
потребителей
могут
быть
значительно
выше
вместимости
транспортных средств.
Схожая задача транспортной маршрутизации перевозок "ро-ро"
(Rollon-Rolloff Vehicle Routing Problem) была рассмотрена Ball et al в [29] и
De Meilemeester et al [149]. Задача SDVRP с погрузкой и доставкой
рассмотрена Nowak [160].
В [74] были рассмотрены структурные характеристики задачи. В
частности,
если
матрица
расстоянии
удовлетворяет
неравенству
треугольника, то существует оптимальное решение SDVRP, где никакие два
пути не имеют более одного общего клиента с раздельной доставкой. В [23]
задались вопросом "разделять или нет". Первым делом было показано, что
если матрица расстояний удовлетворяет неравенству треугольника, то
отношение минимального числа путей, необходимых для обслуживания всех
клиентов задачи VRP, к минимальному числу путей задачи SDVRP всегда
будет не больше 2. Они также доказали, что эта граница является строгой.
Отношение значений дистанции оптимальных решении задач VRP и SDVRP
всегда будет не больше 2. Таким образом, использование раздельных
20
доставок позволяет получить значительный выигрыш в расстоянии. Также,
было проведено эмпирическое исследование последнего соотношения для
выявления его зависимости от расположения клиентов и их потребностей.
Был сделан вывод о том, что сокращение стоимости перевозок происходит,
по всей видимости, за счет уменьшения числа используемых путей, вне
зависимости от расположения клиентов. При этом имеется зависимость от
потребностей клиентов и вместимости транспортных средств. Наибольший
выигрыш от использования раздельных доставок достигнут, когда средняя
потребность клиента находилась между 1/2 и 3/4 вместимости ТС.
Вычислительные эксперименты в [50] также подтверждают эти данные.
1.2 Методы решения задач транспортной маршрутизации
В связи с высокой вычислительной сложностью задач маршрутизации
вне зависимости от их класса, полный перебор маршрутов не представляется
возможным для сколько-нибудь значительной размерности. Поэтому для
решения задачи разрабатывались эвристические методы. Стоит отметить, что
одновременно производился и поиск точных методов, способных решить
задачу небольших размерностей за разумное время.
Обобщенные варианты эвристик, названные метаэвристиками, впервые
были разработаны и описаны Гловером в 1986 году [97]. Как правило,
адаптация метаэвристики к конкретной задаче проще, чем разработка
алгоритма с нуля, а сами метаэвристики могут находить решения задач,
близкие к оптимальным, за разумное время.
Список методов, которые применялись для решения разных задач VRP,
приведен в таблице 1.1.
21
Таблица 1.1. Точные, эвристические и метаэвристические методы решения
различных классов задач VRP.
Задача
Точные методы
Эвристические и
метаэвристические методы
CVRP
- Динамическое
Эвристики:
программирование [57, 16].
- Метод вариации (метод
- Метод ветвей и границ.
Жилетта и Миллера) [94].
Максимальная размерность
- Кластеризация (метод
решенной задачи – 286
Фишера и Джайкумара) [83].
пунктов [130]
- Алгоритмы, основанные на
- Метод ветвей и отсечений
паросочетаниях [68].
(комбинация метода ветвей и
- Алгоритмы улучшения
границ с методом секущих
путей [196, 198].
плоскостей Гомори). [81]
- Метод лепестков [181].
- Метод ветвей, отсечений и
Метаэвристики:
цены (комбинация метода
- Алгоритм муравьиной
ветвей и отсечений с методом колонии [46, 72].
генерации столбцов). [85]
- Генетические алгоритмы
- Формализация сети
[101].
двухпродуктовых потоков.
- Процедура жадного
[28]
случайного адаптивного
поиска [26]
- Детерминированный отжиг
[77]
- Алгоритм модельной
закалки [162].
- Табуированный поиск [203,
190, 12].
- Переменный поиск по округе
22
[122].
- Метод сбережений [59, 144,
MDVRP
197, 201].
- Многоэтапные алгоритмы
(прикрепление клиентов к
депо и решение отдельных
задач CVRP) [95, 197, 11].
- Табуированный поиск [174,
183].
- Эволюционный алгоритм
[161, 193].
- Алгоритм оптимизации
муравьиной колоний [205].
- Многоэтапные алгоритмы
PVRP
(прикрепление клиентов ко
дням иди маршрутам и
решение отдельных задач)
[30, 37, 56, 180, 191].
- Табуированный поиск [60].
SDVRP
- Метод ветвей и границ [73].
- Метод сбережений [76].
- Метод ветвей и отсечений
- Локальный поиск [74, 75].
[35]
- Табуированный поиск [20,
22].
VRPB
- Метод Yano at al (для
- Кластеризация [94].
особых случаев) [206]
- Метод сбережений [66].
- Метод Gelinas (для особых
случаев) [89]
VRPPD
- Метод ветвей и границ [119]. - Перестановки [173].
- Динамическое
- 2-фазный алгоритм Ренода
23
программирование [41, 69].
[173].
- Метод ветвей и отсечений.
- Локальный поиск [199].
Позволил решить задачу из 15 - Табуированный поиск [125].
пунктов [82]
- Генетические алгоритмы
[163].
- Метод отжига [143].
VRPTW
- Метод ветвей и границ [27].
- Метод сбережений [188].
- Динамическое
- Жадный поиск [188].
программирование [69]
- Метод последовательной
вставки [169, 188].
- Локальный поиск [170, 196].
- Генетические алгоритмы
[194, 195].
SVRP
- Стохастическое
- Априорная
программирование [74, 126,
последовательность [40].
127, 189].
- Цикличная эвристика [39].
- Метод отжига [192].
1.3 Задача коммивояжера (TSP, Traveling salesman problem)
Задача
заключается
в
поиске
кратчайшего
(самого
дешевого)
замкнутого маршрута в графе, который проходит через все вершины графа,
хотя бы один раз.
Впервые данная задача была сформулирована в руководстве успешного
коммивояжера в 1832 году [156]. Также там был представлен оптимальный
замкнутый маршрут, проходящий через 45 городов Германии (рисунок 1.2).
24
Рисунок 1.2 Задача коммивояжера и еѐ решение.
Общая постановка задачи впервые была сделана в 20 годах 20 века,
судя по всему [184], Карлом Менгером [146], который формализовал задачу,
названную им впоследствии задачей посланника (messenger problem).
Доработанная формализация задачи была дана им в 1929 г. [148]. Далее, он
рассмотрел алгоритм полного перебора маршрутов, а также указал на то, что
использование эвристик, основанных на поиске ближайшего соседа, в общем
случае, может не привести к нахождению оптимального маршрута [145].
В 1931 году, Менгер посетил с лекциями Гарвард. В результате,
Whitney поставил задачу о нахождении кратчайшего замкнутого маршрута,
проходящего через 48 штатов США. [137]
В 1937 были отмечены связи задачи коммивояжера с играми
Гамильтона [137].
Начиная с 40 годов 20 века, несколько изменилось наполнение работ,
посвященных задаче коммивояжера. В данных работах впервые были
указаны характеристики данной задачи.
Менгер в [147] вернулся к вопросу нахождения кратчайшего пути,
походящего через заданное множество точек в метрическом пространстве.
25
Он следует за работой Milgram [150], посвященной нахождению кратчайшей
Жордановой кривой, которая проходит через заданное, не обязательно
конечное, множество точек в пространстве. И так как множество может быть
бесконечным, кратчайшая кривая может и не существовать.
Fejes [79] исследует задачу задачу нахождения кратчайшей кривой,
проходящей через n точек в единичном квадрате. Впоследствии, Verblunsky
[200] показал, что ее (кривой) длина меньше 2
2.8 n . Дальнейшие работы
в этом направлении включают [33, 80].
Нижние границы ожидаемого значения кратчайшего пути через n
случайных точек на евклидовой плоскости были изучены Mahalanobis [138],
для оценки стоимости выборочной оценки площади земли под джут в
Бенгалии. Данное исследование проводилось в 1938 году. Основная доля
затрат легла на транспортировку людей и оборудования, в связи с чем и
возникла необходимость решения задачи коммивояжера. Mahalanobis дал
оценку минимальной длины пути
n 1
, однако доказательство приводить
n
не стал.
Данное исследование было продолжено Джессеном [116], который
эмпирически получил похожий результат для манхэттенской метрики.
Marks [141] дал доказательство результата Mahalanobis. Фактически, он
показал, что
1
A
2
n
1
, где A – площадь региона. Ghosh [92] показал,
n
что асимптота данной оценки близка к ожидаемому значению, получаемому
эвристикой, уступая верхней границе в 1.27 An . Также, он привел оценку
вычислительной сложности задачи.
В
[137] упоминается, что в 1948 году начали предприниматься
попытки связывания задачи линейного программирования с задачей
коммивояжера.
26
Robinson
сделала
[177]
неудачную
попытку
решить
задачу
коммивояжера, рассмотрев в качестве релаксации задачу о назначениях. В
результате, был получен метод сокращения циклов. Связь состояла в том, что
задача о
назначениях
в качестве результата
требует
оптимальную
перестановку, а задача коммивояжера – оптимальную циклическую
перестановку. Данный доклад Робинсон для RAND может считаться самым
ранним использованием термина "задача коммивояжера".
Beckmann и Koopmans [34] показали, что задача коммивояжера может
быть сформулирована, как квадратичная задача о назначениях, для которой,
однако, неизвестно быстрых методов решения.
Существенный прогресс был достигнут в работе Dantzig, Fulkerson и
Johnson [64]. В ней было предложено несколько новых методов для решения
задачи коммивояжера, которые в данный момент считаются базовыми в
комбинаторной оптимизации.
По теореме Birkhoff [42], выпуклая оболочка строк матрицы
перестановок n×n в точности повторяет дважды стохастические матрицы, то
есть неотрицательные матрицы у которых сумма по столбцам и строкам
равна 1.
xi , j
0, i, j
0, n
xi , j 1, i
0, n
xi , j
0, n
n
j 0
n
1,
j
i 0
Это позволяет решить задачу о назначениях как задачу линейного
программирования.
Для
этого,
необходимо
описание
в
линейных
неравенствах многогранника задачи коммивояжера – выпуклой оболочки
матриц цикличных перестановок. Это позволяет добавить неравенства,
убирающие подциклы.
xi , j 1, I
1,..., n ,
I
1,..., n .
i I, j I
27
Предполагалось, что этих неравенств достаточно, чтобы отсечь
нецикличные перестановки. Однако, в 1953 году было показано, они не
отсекают все подциклы при n≥5 [111].
Впрочем, эти неравенства могут быть полезными для задачи
коммивояжера, так как может быть получена нижняя граница длины
оптимального маршрута. Расчет нижней границы производится с помощью
симплекс метода с использованием неравенств в качестве секущих
плоскостей. Таким образом, авторы смогли получить кратчайший путь через
избранные города 48 штатов США, что оказалось близко к упомянутым
выше задачам Whithey и Robinson.
Ранние исследования многогранника задачи коммивояжера приведены
Heller [108, 109, 110, 111, 112, 113], Kuhn [121], Norman [158], Robacker [175].
В
последней
работе
также
приведены
расчетные
исследования,
показывающие вероятность того, что случайному набору исходных данных
понадобятся неравенства, убирающие подциклы.
В
[160]
было
показано,
что
оптимальный
маршрут
задачи
коммивояжера на евклидовой плоскости не пересекает сам себя.
Позднее были предложены следующие подходы:
- линейное программирование с эвристикой 3-exchange [153]
- метод графического решения [31], который является схемой для
перебора вариантов с целью получения решения, близкого к оптимальному.
Также в данной работе был приведен разбор задачи из 10 пунктов, которая
была решена данным методом от руки, что показало практическую
применимость метода для решения малоразмерных задач. Dantzieg, Fulkerson
и Johnson [64] показали, что их метод уступает данной эвристике.
- алгоритмы 3-opt оптимизации. Первая попытка использования 3-opt
была скомбинирована со схемой перебора [43, 44]. Автор проверил алгоритм
на примерах Robacker and Barachet и новом примере из 10 городов.
Отмечено, что алгоритм бесполезно использовать для решения задачи
Dantzig-Fulkerson-Johnson о 42 городах, в связи с его медленной работой.
28
Еще один вариант 3-opt оптимизации был предложен в [62]. Автор решил
задачу Dantzig-Fulkerson-Johnson о 42 городах расчетами вручную за 70
часов. Позднее, в [134] алгоритм Croes был дополнен и был использован для
примера из 105 пунктов.
- Метод ветвей и границ [78], использует задачу о назначениях с целью
получения нижней границы. Алгоритм проверялся на примерах, в которых
было до 10 пунктов.
- Неявный перебор Rossman and Twery [179], который был использован
для решения примера из 13 пунктов вручную.
-
В
[36]
задача
коммивояжера
была
показана
как
пример
комбинаторной задачи, которая может быть решена методами динамического
программирования. Согласно данной работе, компьютеры того времени
позволяли эффективно решать задачу коммивояжера данным методом вплоть
до 17 пунктов.
- Использование секущих плоскостей Гомори. Их использование было
показано на примере задачи из 5 пунктов в [123] Также, в [151], где вначале
дается формализация задачи коммивояжера в виде задачи целочисленного
программирования, которую уже решали с помощью секущих плоскостей.
Также было показано действие алгоритма на примере Барачета из 10
пунктов.
Свои
версии
использования
секущих
предложили в [142] и [14]. Позднее, в [124]
плоскостей
Гомори
приведен алгоритм
использующий секущие плоскости Гомори для решения задачи из 100
пунктов. В [104] их использование помогло решить пример из 120 пунктов.
-
В
[44]
и
[142]
использованы
алгоритмы,
основанные
на
целочисленном линейном программировании. Однако наибольший вклад в
развитии данного подхода привнесен в [114]. Приведенный алгоритм
развивает метод Dantzig, Fulkerson и Johnson. Автор решал двойственные
задачи линейного программирования в качестве релаксации; алгоритм
максимального потока Ford-Fulkerson для поиска неверных неравенств;
метод ветвей и границ. Также были приведены результаты вычислительных
29
экспериментов из 20 пунктов в евклидовом пространстве. Из 60 запусков, 59
были решены без ветвлений, а оставшийся пример потребовал единственную
ветвь. Большие примеры не были решены в связи со сложностями с его
решателем задач линейного программирования.
- Алгоритм самой дешевой вставки [120], который предлагалось
использовать для улучшения секции маршрута. Автор использовал свой
алгоритм на примере задачи из 57 пунктов. В [171] были предложены
некоторые дополнения к данному методу.
- В 1964 г. [135] впервые вводится термин "ветви и границы", которым
и
был
назван
соответствующий
точный
метод
решения
задачи
коммивояжера, также описанный в этой работе. Приведены результаты
использования метода ветвей и границ: решение задачи из 25 пунктов с
помощью компьютера IBM 7090; решение ассиметричной задачи из 30
пунктов со случайными расстояниями с помощью компьютера IBM 7090;
решение примера из 10 пунктов вручную в течение часа. Позднее в [131]
было предложено использовать в качестве нижней границы минимальное
остовное дерево. В [185] были представлены идеи для улучшения
производительности алгоритма в симметричных примерах.
- Локальный поиск. Был использован в [172]. Самый крупный пример –
задача из 57 пунктов, рассмотренная в [104]. На каждом из примеров,
локальный поиск давал результат не хуже, чем метод самой дешевой вставки.
- Перебор маршрутов. Эвристики, основанные на переборе маршрутов,
были предложены в [154, 155, 176].
В
последнее
время
было
также
предложено
использование
метаэвристик:
-алгоритм отжига [1].
- табуированный поиск [139]
- генетические алгоритмы [32, 168, 178]
- Процедура
жадного случайного адаптированного поиска (Greedy
Randomized Adaptive Search Procedure – GRASP). [140]
30
- Искусственные нейронные сети. [18]
- муравьиная колония. [71]
- метод цепного исключения. [86, 87]
- алгоритм разбросанного поиска. [96]
- направленный локальный поиск. [54]
- метод роя частиц. [100, 133]
- поиск по изменяемой округе. [152]
В 2004 году было получено точное решение задачи коммивояжера,
маршрут которой состоял из 24978 городов Швеции [19]. Маршрут был
получен с помощью эвристики Lin-Kernighan. Полученный маршрут является
оптимальным согласно программному коду Concorde TSP.
Кроме того, стоит отметить существование особых случаев задачи
коммивояжера, которые имеют эффективное решение [48]:
- задачи коммивояжера решаемые пирамидально. Маршрут (1, i1, i2, ...,
ir, n, j1, j2, ..., jn-r-2) называется пирамидальным, если i1<i2<...<ir и j1>j2> ...> jn-r2.
Первый пример такой задачи, которая может быть решена эффективно:
расстояния между пунктами задаются матрицей
0 u1 u2
... un и v1
v2
... vn
C
cij
ui v j , где
0 [1].
- некоторые случаи задачи коммивояжера на евклидовой плоскости:
а. Выпуклые задачи коммивояжера. Примерами подобных задач
являются множества точек Калмансона и Демиденко [10] (см. рисунки 1.3 и
1.4)
Рисунок 1.3. Множество точек Калмансона.
31
Рисунок 1.4. Множество точек Демиденко.
б. задачи коммивояжера расположенные на параллельных
прямых (или почти параллельных прямых). В [63] был предложен метод,
которые решает подобную задачу коммивояжера за время O(n3) (O(n2) в
случае, если число параллельных прямых k=3.
в. Задача коммивояжера в виде ожерелья [182]. Случай задачи,
когда вокруг каждого из n пунктов существует n окружностей, таких что
каждая из них пересекает ровно две другие окружности (см. рисунок 1.5).
Рисунок 1.5. Задача коммивояжера в виде ожерелья
- задачи коммивояжера с переставленной матрицей Монге. Матрица C
называется переставленной матрицей Монге, если существует перестановка
ø, такая что Сε,ø (ε – определяет перестановку) является матрицей Монге.
Матрица m×n A называется матрицей Монге, если при любых i, j, k, l таких,
что 1 i k
m и 1
j l
n , соблюдается неравенство Ai , j
Ak ,l
Ai ,l
Ak , j .
32
Перестановка ø является оптимальным решением задачи коммивояжера для
данной матрицы расстоянии C. [49]
- задача коммивояжера, в которой пункты расположены на осях OX и
OY ортогональной системы координат. [53]
1.4 Выводы
1.
Был произведен обзор задач транспортной маршрутизации и ее
вариантов.
2.
Имеется множество вариантов задач транспортной маршрутизации –
CVRP, SDVRP, VRPPD, VRPTW, SVRP и т. д. Частным случаем задач
транспортной маршрутизации является задача коммивояжера, которая
исторически была рассмотрена первой.
3.
Задачи
транспортной
маршрутизации
характеризуются
высокой
вычислительной сложностью, так как относятся к классу NP-сложных
задач. В результате имеется необходимость в разработке и применении
эвристических и метаэвристических методов для решения задач
маршрутизации.
4.
Использование раздельных доставок (split deliveries) в задачах
маршрутизации позволяет получить более короткий маршрут.
5.
Задачи с забором и доставками рассмотрены в менее чем 10% работ,
посвященных задачам транспортной маршрутизации.
33
2. МАТЕМАТИЧЕСКАЯ МОДЕЛЬ МОНОНОМЕНКЛАТУРНОЙ
ОПТИМИЗАЦИОННОЙ ЗАДАЧИ МАРШРУТИЗАЦИИ
ТРАНСПОРТНЫХ СРЕДСТВ
2.1 Задача 1
Пусть имеется одно транспортное средство (далее ТС) с ограниченной
вместимостью, первоначально расположенное в депо, в которое ТС должно
вернуться после окончания перевозок. Следует перевезти однородный груз
из пунктов производства в пункты потребления. В каждом из пунктов
производства имеется определѐнное количество груза, которое необходимо
оттуда вывести. В каждый из пунктов потребления определѐнное количество
груза необходимо доставить. Груз доставляется исключительно за счет
пунктов-производителей, без использования депо. Предположим, что ТС
может посещать каждый пункт (кроме депо) один раз. Возникает
естественная задача определения величины Smin – минимальной вместимости
ТС, при которой перевозки возможны. Таким образом, задача 1 является
оптимизационной.
Будем считать, что все пункты занумерованы числами 0,1,…,n, депо
присвоен номер 0. Через a(i) обозначим вес груза в пункте производства (в
этом случае a(i)>0) или потребность в пункте потребления (тогда a(i)<0).
Допускается, что депо совпадает с пунктом производства, в противном
случае a(0)=0. Естественно считать, что
n
a(i) 0.
i 0
Необходимо
найти
минимальное значение
S, удовлетворяющее
следующему условию. Существует перестановка b(0), b(1),…,b(n) (b(0)=0)
множества {1,…,n}, для которой 0
k
a (b( j )) S при k=0,1,…,n.
j 0
34
Поставленную задачу можно свести к булевой задаче линейного
программирования. Для этого введем матрицу перестановки X: Xij=1
(i,j=0,1,…,n), если число j расположено на i-ом месте перестановки и 0 в
противном случае. Тем самым X00=1.
Должны выполняться следующие условия.
(1)
Xij {0,1},
n
i 0
X ij 1,
(2)
n
j 0
X ij 1,
(3)
k
n
0
i 0 j 0
S
X ij a( j ) S (k 1,..., n),
(4)
(5)
min.
(1)-(5) это задача линейного целочисленного программирования. Для
таких задач, которые относятся к классу NP-трудных, разработан целый ряд
точных
(ветвей
и
границ,
отсечений),
а
также
эвристических
и
метаэвристических алгоритмов.
Приведем оценки величины Smin.
Алгоритм
1.
Пусть
p (1),..., p (k )
-
положительные
члены
последовательности (a(i)) , т.е. объемы грузов в пунктах производства,
q (1),..., q(l )
-
потребности
отрицательные
груза
в
члены
пунктах
последовательности
потребления.
Определим
(a(i)),
т.е.
индуктивно
следующие величины. k1 – максимальное натуральное число, для которого
k1
p(i) S ,
l1
–
максимальное
натуральное
число,
для
которого
i 1
k1
i 1
p(i)
l1
q( j ) 0, k2 – максимальное натуральное число, для которого
j 1
35
k2
l1
p(i)
i 1
k2
q( j ) S , l2 – максимальное натуральное число, для которого
j 1
l2
p(i)
i 1
q( j ) 0 и т.д.
j 1
Предложение 1. Если S≥2a*, где a* max a (i ) , то алгоритм 1
продуктивен при любом упорядочивании весов грузов.
Доказательство. Пусть натуральное число k1 из алгоритма 1 найдено.
Очевидно,
S
k1
что
p(i ) a *
i 1
k1
i 1
k1≥2.
Из
k1
т.е.
максимальности
p(i) S a* a*
k1
q(1) .
i 1
следует
Отсюда
неравенство
следует,
что
p(i ) q(1) 0. Таким образом, число l из алгоритма 1 положительное.
1
k1
Далее из определения величины a* следует неравенство
тогда
k1
S
l1
p(i )
i 1
q( j )
a*
p k1 1 ,
p(i)
i 1
l1
q( j ) a*, а
j 1
откуда k2>k1. Далее по индукции
j 1
построение продолжается до исчерпания последовательности грузов. ■
Тем самым предложение 1 доказано. ■
Имеется более строгая оценка величины Smin.
Предложение
2.
Справедлива
следующая
оценка
Smin:
max|a(i)|≤Smin<2 max|a(i)|. Верхняя оценка является точной и не улучшаемой,
то есть для любого
>0 существуют число n и последовательность
a(0),…,a(n), для которых будет справедливо неравенство S>(2
Доказательство.
Оценка
снизу
очевидна.
) max|a(i)|..
Воспользуемся
обозначениями a+=(|a|+a)/2, a =(|a| a)/2. Если max|ai+|=max|ai |, то есть
максимальный из грузов в пункте производства равен максимальной
потребности в пункте потребления, то их можно исключить из рассмотрения,
поскольку, расположив соответствующие пункты в последовательности на
двух первых местах, доставку из одного пункта в другой можно осуществить
ТС с вместимостью, равной max|ai|<2 max|ai|, после чего ТС остается пустым.
36
Продолжая,
получим
последовательность
грузов,
для
которой
max|ai+| max|ai |. Докажем, что для такой последовательности грузов
достаточно ТС вместимости max|ai+|+max|ai |<2 max|ai| (можно считать, что в
правой
части
максимум
берется
по
элементам
исходной
последовательности). Действительно, на первом шаге в ТС можно погрузить
любой из положительных грузов. Пусть в некоторый момент загрузка ТС не
превосходит max|ai |. Если еще есть пункты производства, в которых груз
остался, то оставшейся вместимости достаточно для погрузки любого из этих
грузов. В противном случае и при загрузке ТС, превосходящей max|ai |, груза
в ТС достаточно для разгрузки в любом пункте потребления. Таким образом,
пока есть необработанные пункты, процесс можно продолжить, что и
требовалось.
Для
доказательства
второго
утверждения
при
некотором
>0
рассмотрим следующую последовательность весов: (k+1) грузов равны (+k) и
k
грузов
равны
( k 1).
Очевидно,
что
S=2k.
Отношение
2k/max{|ai|}=2k/(k+1)>(2 ) при достаточно большом k. ■
Заметим, что для последовательности (1, 1,
2) нижняя оценка
достигается.
2.2 Задача 2
Имеется
одно
транспортное
средство
(ТС)
с
ограниченной
вместимостью S, первоначально расположенное в депо, в которое ТС должно
вернуться после окончания перевозок. Следует перевезти однородный груз
из пунктов производства в пункты потребления. В каждом из пунктов
производства имеется определѐнное количество груза, которое необходимо
оттуда вывести, в каждый из пунктов потребления определѐнное количество
37
груза
необходимо
доставить.
Стоимость
проезда
между
пунктами
определяется только расстоянием. Груз доставляется исключительно за счет
пунктов-производителей, без использования складов. Требуется доставить
груз так, чтобы стоимость перевозок была минимальной.
Нумерация пунктов и веса в грузах пунктов аналогичны задаче 1.
Задана матрица CI расстояний между пунктами: (CI)ij (i,j=0,1,…,n) –
расстояние от i-го пункта до j-го. Считаем, что все расстояния конечные,
причем матрица не обязательно симметрическая. Возможно, что кратчайший
путь между некоторыми пунктами проходит через другие пункты.
Пусть ТС может посещать каждый пункт (кроме депо) один раз.
Необходимо найти перестановку b(0), b(1),…,b(n) (b(0)=0) множества
{1,…,n}, для которой 0
k
a(b( j )) S
при k=0,1,…,n, такую, чтобы общая
j 0
стоимость перевозки являлась минимальной.
Для данной задачи предложено три формализации – квадратичная
булева, линейная целочисленная и линейная булева.
Квадратичная булева формализация.
Заметим, что матрица расстояний при перестановке пунктов в
соответствии с матрицей X из задачи 1 имеет вид CX=XCIXT. Индекс I у
исходной матрицы CI это указание на единичную матрицу.
В этом случае формализация задачи имеет следующий вид. Найти
булеву матрицу X, такую, что выполняются условия (1)-(4) и при этом
n 1
CX
i ,i 1
CX
n ,0
min.
(6)
i 0
(1)-(4), (6) это задача квадратичной булевой оптимизации. Далее
покажем, как существенным повышением размерности можно свести
линейную целочисленную формализацию задачи 2.
38
Линейная целочисленная формализация.
Известен целый ряд линейных формализаций задачи коммивояжера
(обзор см. [70]). Для наших целей более всего подходит модификация
метода, предложенного в ряде работ (например, [88]).
Введем булевы переменные Yij (i,j=0,…,n), равные 1 тогда и только
тогда, когда следующим после i-го пункта на пути следования ТС является jй пункт. Выполняются следующие условия.
n
Yij 1 (i 0,..., n)
(7)
j 0
(из каждого пункта ТС выезжает в единственный пункт),
n
Yij 1 ( j 0,..., n)
(8)
i 0
(в каждый пункт ТС прибывает из единственного пункта),
Y00=0
(9)
(из нулевого пункта ТС выезжает в какой-нибудь другой пункт – для
других пунктов это будет следовать из следующих условий)
Введем целочисленные переменные vi (i=1,…,n) такие, что:
1 vi n
(10)
(vi–vj)+nYij n–1 (i,j=1,…,n)
(11)
Справедливо следующее утверждение:
Предложение 3. Для всякого цикла, удовлетворяющего условию задачи,
существует решение системы (7)-(11). Обратно, всякое решение системы
(7)-(11) определяет цикл, содержащий все пункты. При этом переменные v i
имеют смысл номеров пунктов в порядке прохождения в цепи, содержащей
все пункты за исключением базы.
Доказательство. Если из некоторого цикла удалить пункт 0 (базу) и
переменным vi придать указанный смысл, то все условия (7)-(11) очевидным
образом выполняются. Пусть теперь величины Yij (i,j=0,…,n), vi (i=1,…,n)
удовлетворяют условиям (7)-(11). Если Yij=0, то условие (11) выполняется
при любых значениях vi, удовлетворяющих условию (10). Построим
39
ориентированный граф, вершины которого помечены числами 1,2,…,n, а
наличие дуги (i,j) соответствует тому, что Yij=1. Из равенства Yij=1 и условия
(11) следует, что vi–vj
1, т.е. в построенном графе нет циклов. Из условия
(7) (или (8)) следует, что (n+1) из величин Yij (i,j=0,…,n) равны 1, при этом, из
условия (9) вытекает, что из величин Yij (i,j=1,…,n) равных 1 ровно (n 1).
Таким образом, соответствующий неориентированный граф является
деревом. Из условий (7) и (8) каждая вершина графа имеет полустепени
входа и выхода не более 1. Тем самым, построенный граф является простой
цепью. Поскольку значений vi столько же, сколько вершин в графе, причем
при наличии дуги (i,j) в силу условия vi–vj
1 разным вершинам
соответствуют разные значения vi, то в действительности vi–vj= 1, а это
означает, что vi действительно номера вершин в порядке прохождения по
цепи. В силу условия (7), в пункт, соответствующий первой вершине цепи
груз доставляется из некоторого пункта. Это может быть или база, или пункт,
соответствующий последней вершине построенной цепи. Но второй случай
противоречит условию (9). Аналогично с последней вершиной цепи. Тем
самым, построен цикл нужного вида. ■
Введем булевы переменные Zsk равные 1 тогда и только тогда, когда
vs k (s,k=1,…,n). Справедливы ограничения:
Zsk (1+k vs)/(2n) (s,k=1,…,n)
(12)
(если правая часть положительная, то Zsk=1).
n
n
Z sk
n(n 1) / 2
(13)
s 1 k 1
Из условий (12) и (13) следует, что Zsk=0 при vs>k.
Условие непереполнения и неотрицательности веса груза в ТС при
посещении каждого пункта:
n
0 a0
Z sk as
S (k 1,..., n)
(15)
s 1
Целевая функция имеет вид:
40
n
n
Yij cij
min
(16)
i 0 j 0
Таким образом, переменные поставленной задачи: Yij – булевы, их
(n+1)2; Zsk– булевы, их n2, vi – целочисленные, их n. Общее число
ограничений имеет порядок O(n2).
Линейная булева формализация.
В качестве неизвестных аналогично [167] примем булевы переменные
X ijk , равные 1 тогда и только тогда, когда на k-м шаге ТС переезжает из i-го
пункта в j-й.
Ограничения:
n 1 n
X ijk
1 ( j 1,..., n)
(17)
k 1 i 0
(из каждого пункта ТС после погрузки или разгрузки выезжает один
раз);
n 1 n
X ijk
1 (i 1,..., n)
(18)
k 1 j 0
(в каждый пункт ТС для погрузки или разгрузки прибывает один раз);
n
n
(19)
X ijk 1 (k 1,..., n 1)
i 0 j 0
(на каждом шаге ТС совершает одну поездку);
n
X in0 1 1
(20)
i 1
(на (n+1)-ом шаге ТС должно вернуться на базу из какого-нибудь
другого пункта);
n
(21)
X 01 j 1
j 1
(на нулевом шаге ТС выезжает с базы в какой-нибудь другой пункт);
n
n
(22)
X ijk
X kjp 1( j 0,..., n; k 1,..., n)
i 0
p 0
(из j-го пункта ТС выедет на (k+1)-м шаге тогда и только тогда, когда
на k-м шаге в этот пункт ТС прибудет);
41
Предложение 3. Любое решение системы (17)-(22) порождает цикл,
содержащий все вершины по одному разу (гамильтонов цикл), в котором
последовательные дуги проходятся в последовательные шаги.
Доказательство. Из условия (21) следует, что существует
единственный пункт i1 0, для которого X 01i1 1 . Пусть по индукции построена
цепь (0,i1,…,ik) такая, что X iss 1is
равенства X ikk 1ik
1 следует, что
1 ( s 1,..., k , k
n
n, i0
0). Из условия (17) и
X iikk 1 . Из равенства (23)
i 0
существует единственный пункт ik+1, для которого X
n
X ikk p1 1 , т.е.
p 0
k 1
ik ik 1
1. Проверим, что
ik+1 {i1,…,ik}. Если бы выполнялось обратное, то существовал бы пункт is (s<
k+1), для которого X issik 1 1. Но это противоречит условию (17). Таким
образом строится цепь (0,i1,…,iN-1), которая, содержит все пункты. В силу
условий (18) и (20) X inn 01 1. Тем самым, построен цикл с нужными
свойствами. ■
Следующее ограничение отражает недопустимость переполнения ТС и
неотрицательность груза на любом начальном отрезке маршрута.
p n
n
(23)
0
X ijk ai S ( p 1,..., n).
k 1 j 0 i 0
В общем случае система (17)-(23) несовместна. Справедливо
следующее утверждение.
Предложение 4. Если S 2 max{|ai|}, то система (17)-(23) совместна.
Доказательство. Докажем, что в любой ситуации найдется пункт
производства, из которого ТС может вывезти груз, или пункт потребления, в
который ТС может груз завезти. На первом шаге, поскольку a0 S, груз из
базы вывезти можно. Пусть в некоторый момент загрузка ТС равна b.
Возможны три ситуации.
a) b S/2 и груз вывезен из всех пунктов производства. В силу
n
условия
a(i) 0 потребность в каждом из оставшихся пунктов потребления
i 0
не превосходит b, т.е. маршрут можно продолжить.
b)
b S/2 и груз не вывезен из всех пунктов производства. В этом
случае S–b S/2 max{|ai|}, т.е. груз можно вывезти из любого оставшегося с
грузом пункта производства.
c)
b S/2. Аналогично предыдущему, груз можно завезти в любой
пункт потребления. ■
42
Целевой функцией является общая стоимость перевозок:
n 1 n
(24)
n
X ijk cij
min.
k 1 j 0 i 0
(17)-(24) – задача линейного целочисленного программирования. Число
неизвестных равно (n+1)3, число ограничений имеет порядок О(n2).
Были рассмотрены следующие методы решения задачи 2.
1. Точные методы
1.1 Линейное целочисленное программирование.
1.2 Линейное булево программирование.
1.3 Квадратичное булево программирование.
1.4 Метод ветвей и границ.
2. Эвристические методы
2.1 Алгоритм 1 со случайно генерируемыми перестановками. Алгоритм
1, как следует из предложения 2, результативен при любом упорядочивании
пунктов для достаточно больших S. Следует иметь в виду, что его
использование может не привести к оптимальному решению ни при каком
упорядочивании.
ПРИМЕР 2. Пусть пункты расположены в вершинах квадрата, веса в
порядке обхода квадрата равны 1,
1, 1,
1 (база является пунктом
производства), дороги совпадают со сторонами квадрата, вместимость ТС
равна 2. Очевидно, что оптимальный маршрут есть последовательный обход
сторон квадрата. В то же время, алгоритм 1 приводит к последовательности
грузов 1, 1, 1, 1, эта последовательность оптимальной не является.
Перестановки генерируются случайно так, что вероятность появления
каждой перестановки равна
1/ n!.
Процесс прекращается в соответствии с
принятыми правилами останова.
2.2 Вначале из положительных значений последовательности {a(i)}
выделяется подмножество с максимальной суммой, не превосходящей S
43
(решается задача о наполнении рюкзака). Затем из отрицательных значений
выделяется подмножество с минимальной суммой, при которой общая сумма
обоих выделенных подмножеств неотрицательная. Процесс продолжается до
исчерпания последовательности {a(i)}. Таким образом, получаем зоны
положительных и отрицательных значений в последовательности.
Затем, меняя пункты, в которых стыкуются положительные и
отрицательные отрезки, методом ветвей и границ на каждом из отрезков
минимизируем длину пути.
2.3
Расположим
вначале
положительные
элементы
из
последовательности a(0),…, a(n) по убыванию, затем отрицательные по
убыванию модулей. Если при некотором i, для которого a(i)>0, сумма
начального отрезка больше S, причем для предыдущих индексов это не так,
то находим первое из отрицательных чисел (пусть его номер j), для которых
сумма начального отрезка меньше S. После этого отрезок от i 1 до j
элементов
переворачивается
зеркально.
Если
накопленные
суммы
полученной последовательности принимают отрицательные значения, то
действуем аналогично. Построение показано на рисунке 2.1.
Рисунок 2.1 Алгоритм 2.3.
44
В результате выделяются зоны положительных и отрицательных
значений
в
последовательности.
Затем,
минимизируем
длину
пути
аналогично алгоритму 2.2.
2.4 Основана на алгоритме построения минимального остовного дерева
по алгоритму Прима [12]. Вначале выбирается допустимый пункт, наиболее
близкий к депо. На каждом из последующих шагов выбирается допустимый
пункт, который ближе всего к одному из пунктов, выбранных на
предыдущих шагах. Далее аналогично алгоритму 2.2 переставляются пункты
стыковки положительных и отрицательных отрезков.
2.5 На каждом шаге ТС выбирает пункт, куда оно отправится на
следующем шаге. Для этого ТС перебирает все возможные допустимые
варианты перемещения на k последующих шагов. Из них выбирается вариант
с наименьшей длиной перемещения и ТС делает один шаг по выбранному
варианту. Далее, снова производится перебор вариантов перемещения на k
последующих шагов, выбирается вариант с наименьшей длиной, делает один
шаг и так происходит до тех пор, пока не будут пройдены все пункты. Перед
запуском алгоритма выбирается значение параметра k.
2.3 Задача 3
Задача аналогичная задаче 2. В отличие от задачи 2, транспортное
средство имеет возможность неоднократного посещения пунктов.
Имеется
одно
транспортное
средство
(ТС)
с
ограниченной
вместимостью S, первоначально расположенное в депо, в которое ТС должно
вернуться после окончания перевозок. Следует перевезти однородный груз
из пунктов производства в пункты потребления. В каждом из пунктов
производства имеется определѐнное количество груза, которое необходимо
оттуда вывести, в каждый из пунктов потребления определѐнное количество
45
груза
необходимо
доставить.
Стоимость
проезда
между
пунктами
определяется только расстоянием. Требуется доставить груз так, чтобы
стоимость перевозок была минимальной, при этом ТС может посещать
пункты один и более раз. Груз доставляется исключительно за счет
производителей, без использования складов.
Нумерация пунктов, веса в грузах пунктов и матрица расстоянии
аналогичны задаче 2.
Необходимо найти план перевозок – последовательность пар (u(0),
v(0)), (u(1), v(1)),…, (u(N), v(N)) (число N априори неизвестно, т.е. тоже
является неизвестным, подлежащим определению), первый элемент каждой
из которых это номер пункта, т.е. u(i) {0,1,…,n}, а модуль второго – вес
вывозимого (при v(i)>0) или доставляемого (при v(i)<0) груза при
соответствующем посещении пункта.
Должны выполняться следующие ограничения.
u(0)= u(N)=0
(25)
(ТС должно начинать и заканчивать движение на базе);
(26)
k
0
v(i) S (k
0,..., N )
i 0
(ограничение на вместимость ТС по ходу движения);
v(i) a( j ) ( j
(27)
0,..., n)
0 i N ,u ( i ) j
(из
каждого
пункта
производства груз
полностью
вывозится,
потребность каждого потребителя удовлетворяется);
если u(i)=j, i=0,...,N; j=0,...,n, то v(i)∙aj≥0
(28)
(из пункта производства груз только вывозится, в пункт потребления
только доставляется – из условия (27) это не следует).
Целевая функция – длина маршрута:
N 1
Cu (i ),u (i
1)
min.
(29)
i 0
Предложение 5. Задача (25)-(29) имеет решение.
46
Доказательство. Допустимое решение легко построить, например, с
помощью жадной стратегии (см. далее). Пусть длина полученного маршрута
равна L. Рассмотрим все планы перевозок при N>
маршрутов больше L. Маршрутов при N
, длина таких
конечное число. Среди них
существует кратчайший, который и является оптимальным. ■
Как обычно, план перевозок, удовлетворяющий ограничениям (25)-(28)
называется допустимым.
Заметим, что стратегии жадного типа «при попадании в какой-нибудь
пункт забери или оставь как можно больше» могут не давать оптимального
решения независимо от последовательности прохождения пунктов. Приведем
соответствующий пример.
На рисунке 2.2 отмечены пункты 0,1,2,3 и соответствующая сеть дорог
(некоторые из них с односторонним движением).
Рисунок
2.2. Пример задачи 3, для которой стратегия жадного типа
неэффективна.
Полагаем, что длины всех отрезков равны 1, Расстояния определяются
как длины кратчайших путей. Например, C1,2=1, C2,1=2, C0,2=2, C2,0=3.
47
Наличие и потребности в грузе в пунктах равны соответственно 2, 2,
1, 1. Оптимальный план перевозок, очевидно, имеет вид:
((0,2),(1, 1),(2, 1),(3,1),(1, 1),(0,0)). Длина маршрута при этом равна 5.
Жадная стратегия приводит к такому плану перевозок: ((0,2),(1, 2),
(3,1), (2, 1), (0,0)). Длина маршрута равна 8.
Пусть величины a(j) (j=0,1,…,n), S – целые. Априори ниоткуда не
следует, что в оптимальном решении задачи (26)-(30) значения v(i) целые.
Однако, среди решений задачи непременно есть целочисленные, как следует
из следующего утверждения.
Предложение 6. Пусть величины S,a(j) (j=0,1,…,n) целые и (u(0), v(0)),
(u(1), v(1)),…, (u(N), v(N)) – допустимый план перевозок. Тогда существует
допустимый план перевозок (u(0), v’(0)), (u(1), v’(1)),…, (u(N), v’(N)),
в
котором грузы v’(i) целые.
Доказательство.
Пусть k – минимальное число, при котором
значение v(k) дробное.
Рассмотрим случай v(k)>0, второй случай исчерпывается аналогично.
Положим v(k)=d r, где d положительное целое число, r (0,1). Положим
v (k)=d. Поскольку
и числа
целые, то справедливо неравенство
, т.е. переполнения ТС
при замене v(k) на v (k) не произойдет.
Заметим, что
, в противном случае общий вес грузов
не может быть целым. Здесь, как обычно,
. Если
, то положим v (i)=0 при i>k и a(i)>0 (т.е. в пунктах
производства). Если
, то найдем такое значение k+1 m <N,
для которого
производства v (i)=0 при k<i m 1, v (m)=v(m)+
. Положим для пунктов
, v (i)=v (i)
при i>m. При прежних объемах выгрузки в пунктах потребления перегруза
ТС не происходит ни в одном пункте маршрута (формально выполняются
ограничения (1)-(4)).
48
Таким образом, можно добиться удлинения начального отрезка
маршрута, на котором грузы v(k) целые. Продолжая процесс, получим
нужный результат. ■
Замечание.
У
целочисленной
задачи
могут
существовать
и
нецелочисленные решения. Приведем соответствующий пример. Пусть сеть
пунктов имеет вид (рисунок 1). Наличие и потребности в грузах
соответственно равны 0,2, 2, 4, вместимость ТС равна 2. Поскольку за один
проход цикла доставить груз невозможно, то оптимальный план перевозок
состоит в двукратном его прохождении. При этом, наряду с целочисленными
решениями (например, ((0,0), (1,2), (3, 2), (2,2), (3, 2)) существуют и
нецелочисленные (например, ((0,0), (1;1.5), (2;0,5), (3, 2), (1;0.5), (2;1,5), (3,
2)).
Были рассмотрены следующие методы решения целочисленной задачи
2.
1.1 Предложение 5 позволяет искать точное решение целочисленной
задачи переборным алгоритмом. Разумеется, это очень трудоемкий процесс,
он реализуем только для задач малых размерностей. Опишем этот алгоритм в
том варианте, который нами применялся, подробнее.
На каждом шаге следует выбрать как следующий допустимый пункт,
так и вес груза (целый), который следует доставить в этот пункт или забрать
из него. Строится дерево вариантов, в которое входят все возможные
маршруты и перемещения грузов, выбирается маршрут с минимальной
длиной пути.
Применялось также несколько эвристических подходов.
2.1 Если загрузка ТС равна максимальной, то следующим будет
ближайший пункт потребления, в котором сохраняется потребность в грузе;
если ТС пустое, то ближайший пункт производства, из которого еще не весь
груз вывезен; если оба условия не выполнены, то выбирается ближайший из
пунктов любого вида. При попадании в пункт производства ТС вывозит весь
49
наличный груз (если позволяет вместимость) либо заполняется полностью.
При попадании в пункт потребления ТС оставляет весь груз (если при этом
не возникает избытка груза) либо заполняет пункт потребления.
2.2 На каждом шаге ТС выбирает пункт, куда оно отправится на
следующем шаге. Для этого ТС перебирает все возможные допустимые
варианты перемещения на k последующих шагов. Из них выбирается вариант
с наименьшей длиной перемещения и ТС делает один шаг по выбранному
варианту. Далее, ТС снова производит перебор вариантов перемещения на k
последующих шагов, выбирает из них маршрут с наименьшей длиной, делает
один шаг и так происходит до тех пор, пока не будут пройдены все пункты.
Перед запуском алгоритма выбирается значение параметра k.
Далее все аналогично предыдущему.
Во время перебора последующих k шагов следует следить за тем,
чтобы не попадать в пункты, которые уже были полностью обслужены, а
также, чтобы заполненное ТС не попадало в пункт производства или пустое
ТС – в пункт потребления. Алгоритм 2.1 является частным случаем данной
эвристики.
2.3 Строится цикл с наименьшей длиной, включающий в себя депо и
все пункты-производители. Также, строится цикл с наименьшей длиной,
включающий в себя депо и все пункты-потребители. Двигаемся по первому
циклу, пока не заполнится ТС, затем переходим в ближайшую точку второго
цикла. Двигаемся по нему, пока ТС не разгрузится полностью. Затем
переходим в ближайший пункт производства и т.д. Пункты, из которых все
вывезено или в которые завезено нужное количество груза, из циклов
исключаются. Если пунктов производства и потребления примерно поровну,
то построение двух оптимальных циклов, проходящих через половину
пунктов, проще построения одного цикла, проходящего через все пункты.
2.4 Метод основан на алгоритме Прима построения минимального
остовного дерева [12]. Вначале разбиваем имеющиеся пункты на подпункты
с весами груза (+1) или (–1) в зависимости от того, какой пункт разбиваем –
50
n
производства или потребления. Таким образом, получаем
i 0
a(i) подпунктов.
Затем выбирается допустимый подпункт, наиболее близкий к депо. На
каждом из последующих шагов выбирается допустимый подпункт, который
ближе всего к одному из пунктов, выбранных на предыдущих шагах. В
результате выделяются зоны положительных и отрицательных значений в
последовательности.
Затем,
меняя
пункты,
в
которых
стыкуются
положительные и отрицательные отрезки, методом ветвей и границ на
каждом из отрезков минимизируем длину пути. Эта стратегия имеет смысл
только при малых весах грузов в пунктах производства и потребностях в
пунктах потребления.
2.5 Производится разбиение пунктов на подпункты, аналогично
алгоритму
D.
Пусть
p (1),..., p (k )
положительные
последовательности (они все равны 1), q(1),..., q(k )
члены
отрицательные (все
равны 1). Берем максимально допустимый начальный отрезок пунктов из
первой последовательности (его длина min{S,k}, затем начальный отрезок
пунктов из второй последовательности той же длины. Если пункты не
исчерпаны, то выбираем следующие отрезки последовательностей по тому
же принципу и т.д.
Перестановки p (1),..., p (k ) и q(1),..., q (k ) генерируются случайно таким
образом,
что
вероятность
появления
каждой
равна
1/k!.
Процесс
прекращается в соответствии с принятыми правилами останова.
51
2.4 Задача 4
Задача 4 является расширением задачи 3. В отличие от задачи 3,
имеется возможность хранения груза в одном или нескольких пунктах
(пункты-склады).
Имеется
одно
транспортное
средство
(ТС)
с
ограниченной
вместимостью, первоначально расположенное в депо, в которое ТС должно
вернуться после окончания перевозок. Следует перевезти однородный груз
из пунктов производства в пункты потребления. В каждом из пунктов
производства имеется определѐнное количество груза, которое необходимо
оттуда вывести, в каждый из пунктов потребления определѐнное количество
груза
необходимо
доставить.
Стоимость
проезда
между
пунктами
определяется только расстоянием. Требуется доставить груз так, чтобы
стоимость перевозок была минимальной. Транспортное средство имеет
возможность неоднократного посещения пунктов. В одном или нескольких
пунктах (пункты-склады) транспортное средство может оставить часть или
весь груз.
Груз доставляется исключительно за счет производителей и
складов, без использования депо.
Нумерация пунктов и матрица расстоянии аналогичны задаче 1.
Каждому пункту присваивается пара чисел (a(i);b(i)).
Через a(i) обозначим вес груза в пункте (аналогично предыдущим
n
задачам). Естественно предполагать, что
a i
0
i 1
b(i)≥0. Если b(i)=0, тогда в пункте нельзя оставлять груз на хранение.
Если b(i)>0, то в пункте можно хранить груз (то есть, это пункт-склад), при
этом b(i) – максимальное количество груза, которое единовременно может
находиться на складе. Соответственно, накладывается ограничение |a(i)|≤b(i),
в случае если b(i)>0.
Имеется ТС с заданной вместимостью S.
52
Необходимо найти последовательность пар
(u(0), v(0)), (u(1), v(1)),…, (u(N), v(N)) (число N также является
неизвестным), первый элемент которых это номер пункта, второй вес груза
вывозимого (v(i)>0) или доставляемого (v(i)<0) при соответствующем
посещении пункта, т.е. u(i) {0,1,…,n}.
Должны выполняться следующие ограничения.
u(0)= u(N)=0
(30)
(ТС должно начинать и заканчивать движение на базе.)
(31)
k
0
v i
S k
0, N
i 0
(Ограничение на вместимость ТС.)
v i
0 i N ,u i
a j
(32)
j 0, n
j
(Из каждого пункта груз полностью вывозится, потребность каждого
потребителя удовлетворяется.)
a j
v i
0 i k ,u i
b j b j
0; j 0, n; k
0, N
(33)
j
(условие не превышения количества грузов на складе)
a j
v i
0 i k ,u i
0 a j
0; j 0, n; k
0, N
(34)
j
(из пункта-производителя нельзя забрать больше груза, чем у него
имеется)
Если u(i)=j,то v(i)×a(j)≥0 если b(j)=0
(35)
(Из пункта производства груз только вывозится, в пункт потребления
только доставляется, если они не являются пунктами-складами)
Целевая функция:
N 1
CI
u i ,u i 1
min
(36)
i 0
Использование складов, позволяет получить более короткий маршрут в
некоторых случаях, как в примере ниже (см. рисунок).
53
2
1
0
3
4
Рисунок 2.3. Пример задачи, для которой использование склада
является выгодным.
Пример. Полагаем, что длины всех отрезков равны 1, Расстояния
определяются как длины кратчайших путей. Например, C1,2=2, C2,4=2, C0,2=1,
C4,0=1.
Максимальная вместимость ТС равна 3.Наличие и потребности в грузе
в пунктах равны соответственно 0, +2, +2, +2, −6. Оптимальный план
перевозок, очевидно, имеет вид:
((0,0), (1,+2), (0, 1), (2,+2), (4, 3), (0,+1), (3,+2), (4, −3), (0,0)). Длина
маршрута при этом равна 10. Если не использовать склад, то длина маршрута
составит 12.
54
Для решения целочисленного варианта данной задачи производился
поиск точного решения задачи переборным алгоритмом. Опишем этот
алгоритм в том варианте, который нами применялся, подробнее.
На каждом шаге следует выбрать как следующий допустимый пункт,
так и вес груза (целый), который следует доставить в этот пункт или забрать
из него. Строится дерево вариантов, в которое входят все возможные
маршруты
и
перемещения
грузов,
поиск
оптимального
маршрута
производится с помощью метода ветвей и границ. Для того, чтобы
исключить возможность перевозки одной и более единиц груза по
замкнутому циклу было сделано следующее. Вначале данная задача
решалась, как задача без складов (задача 3) с помощью одной из эвристик, в
результате чего мы получаем маршрут с заданной длиной пути (текущий
оптимум). Во время процесса перебора, когда длина пути маршрута превысит
длину пути текущего оптимума, перебор по данной "ветке" останавливается
и происходит переход на соседнюю. В случае если найден маршрут, длина
которого меньше длины пути маршрута текущего оптимума, сравнение
длины "веток" производится уже с ним.
55
3. ПОСТАНОВКА ЧИСЛЕННЫХ ЭКСПЕРИМЕНТОВ,
ИССЛЕДОВАНИЕ РЕЗУЛЬТАТОВ.
3.1 Точные решения задачи 2
Проведен сравнительный анализ эффективности использования для
решения задачи 2 четырѐх алгоритмов:
- квадратичного булева (формализация приведена выше, использовался
пакет MATLAB 2011 с установленным расширением cplex 12.2);
- линейного целочисленного
(формализация приведена выше,
использовался пакет MATLAB 2011 с установленным расширением cplex
12.2);
- линейного булева
(формализация приведена выше, использовался
пакет MATLAB 2011 с установленным расширением cplex 12.2);
- ветвей и границ с начальным приближением, построенным по
принципу «первый подходящий» (использовался пакет MATLAB).
Для размерностей n=4..18 генерировались случайно по 100 примеров
(данные сгенерированных примеров приведены в таблицах А.1, А2 и А3).
Сравнительный анализ среднего времени выполнения приведен в
таблице 3.1. Сравнительный анализ среднего количества итерации в процессе
решения в таблице 3.2. Данные по времени выполнения, количеству
итераций и длине найденного маршрута приведены в таблицах А.3, А.4 и
А.5.
Таблица 3.1 Среднее время решения случайного примера, с (точность 5%)
4
5
6
Линейное
Квадратичное
Ветви и
Линейное
целочисленное, булево, с
границы, с
булево, с
с
0,0686
0,0463
0
0,0306
0,235
0,123
0,000156
0,0466
0,856
0,123
0,00140
0,0721
56
7
8
9
10
11
12
13
14
15
16
17
18
13,5
616
0,496
3,88
41,1
490
0,00764
0,0414
0,248
1,61
8,97
52,0
333
0,151
0,294
0,573
1,42
2,99
7,75
14,3
36,2
53,5
131
478
856
Таблица 3.2 Среднее количество итераций в процессе решения случайного
примера (точность 5%)
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
Линейное
Квадратичное
Ветви и
Линейное
целочисленное, булево, с
границы, с
булево, с
с
137
15,8
14,3
1,24
1,4∙103
107
47,7
20,6
4
1,47∙10
841
199
54,2
5
3
2,66∙10
7,46∙10
911
185
6
4
3
9,31∙10
6,67∙10
4,18∙10
736
6,54∙105
1,92∙104
1,98∙103
6,98∙105
1,01∙105
5,79∙103
4,63∙105
1,19∙104
2,21∙106
3,08∙104
1,22∙107
4,73∙104
1,11∙105
1,39∙105
2,67∙105
9,72∙105
1,03∙106
57
При n 8 линейный частично целочисленный алгоритм практически
неприменим, наиболее эффективным оказался целочисленный квадратичный
алгоритм.
Минимальная размерность, при которой случайная задача не была
решена в течение одного часа, для каждого из методов:
- n=14 для метода ветвей и границ;
- n=9 для линейного целочисленного программирования;
- n=20 для линейного булева программирования;
- n=11 для квадратичного булева программирования.
Максимальная размерность, при которой случайная задача была
решена в течение одного часа, для каждого из методов:
- n=15 для метода ветвей и границ;
- n=14 для линейного целочисленного программирования;
- n=28 для линейного булева программирования;
- n=10 для квадратичного булева программирования.
3.2 Зависимость длины оптимального маршрута от вместимости
транспортного средства
Анализировалась влияние роста вместимости ТС на длину пути –
целевую функцию. Для решения задачи 1 был использован пакет MATLAB
2011 с установленным расширением lpsolve 5.5.2.0. Затем с помощью
линейного булева алгоритма решалась задача 2 (использован пакет MATLAB
2011 с установленным расширением cplex 12.2) при минимальной
вместимости ТС – решении задачи 1, при увеличении вместимости ТС по
сравнению с минимальной в 1,1; 1,2;…2,5 раз. Для числа пунктов от 4 до 12
58
было сформировано по 100 примеров, длины усреднялись. Часть результатов
приведена на рис 3.1.
1
0,98
0,96
4
0,94
5
0,92
6
7
0,9
8
0,88
9
0,86
10
0,84
11
0,82
12
0,8
Рисунок 3.1. Влияние увеличения вместимости ТС на длину оптимального
маршрута.
Из приведенного графика можно сделать выводы о том, что:
- повышение грузоподъемности транспортного средства более, чем
в1,7-1,8 раз в сравнении с минимально допустимой не приводит в среднем к
сокращению длины маршрута;
- при увеличении числа пунктов (до n=10) рост грузоподъемности ТС
приводит в среднем к большему сокращению длины цикла. Для n≥10
дальнейшее сокращение длины цикла уже не происходит.
59
3.3 Сравнение эффективности эвристик для решения задачи 2
Для заданного числа пунктов n
- генерируем с помощью датчика случайных чисел величины
a(1),…,a(n-1) из промежутка [ 5, 5], принимаем a(0)
n
a(i);
i 1
- равномерно и независимо генерируем n+1 вещественных чисел –
координаты пунктов (x(i), y(i)) (i=0,…,n) на отрезке [ 5,5], расстояния Ci,j
принимаются равными евклидовым расстояниям между точками.
Для
гарантированной
допустимости
задачи
(предложение
1)
вместимость ТС принимается равной 2*max{|a(i)|:i=0,…,n}.
Для каждого n генерировались 100 задач.
К каждой полученной задаче применялись описанные алгоритмы.
Сводка полученных результатов приведена в таблицах 3.3 и 3.4.
Таблица 3.3Средняя длина маршрута относительно оптимального и среднее
время решения задачи алгоритмами (точность 5%)
Алгоритмы
n
7
Линейное
булево
программирование
1/
0,0306
1/
0,0466
1/
0,0721
1 / 0,151
8
1 / 0,294
9
1 / 0,573
10
1 / 1,42
11
1 / 2,99
4
5
6
Метод
2.1
Метод
2.2
Метод
2.3
Метод
2.4
Метод
2.5, k=1
Метод
2.5, k=2
Метод
2.5, k=3
1,02 /
0,00094
1,05 /
0,00078
1,102 /
0,00156
1,17 /
0,00172
1,24 /
0,00249
1,33 /
0,00374
1,41 /
0,00463
1,51 /
1,01 /
0,00063
1,03 /
0,00155
1,07 /
0,00127
1,12 /
0,00187
1,16 /
0,00345
1,17 /
0,00691
1,26 /
0,0199
1,27 /
1,01 /
0,00093
1,03 /
0,00139
1,08 /
0,00183
1,13 /
0,00203
1,17 /
0,00375
1,17 /
0,00656
1,25 /
0,0201
1,25 /
1,02 /
0,00093
1,05 /
0,00109
1,08 /
0,00126
1,09 /
0,00143
1,11 /
0,00157
1,12 /
0,00482
1,14 /
0,0138
1,13 /
1,05 /
0,00047
1,08 /
0,00078
1,11 /
0,00123
1,12 /
0,0028
1,14 /
0,00125
1,15 /
0,0025
1,17 /
0,0014
1,16 /
1,07 /
0,00094
1,13 /
0,00094
1,15 /
0,00185
1,18 /
0,00282
1,21 /
0,00481
1,22 /
0,00607
1,27 /
0,00701
1,26 /
1,03 /
0,0011
1,06 /
0,00219
1,09 /
0,00591
1,1 /
0,00732
1,17 /
0,0154
1,16 /
0,0255
1,21 /
0,0388
1,24 /
60
12
1 / 7,75
13
1 / 14,3
14
1 / 36,2
15
1 / 53,5
16
1 / 131
17
1 / 478
0,00573
1,539 /
0,00435
1,65 /
0,0086
1,71 /
0,00705
1,78 /
0,00799
1,83 /
0,00902
1,92 /
0,00917
0,149
1,29 /
0,504
1,29 /
2,29
1,34 /
16,3
1,37 /
39,3
1,37 /
339
-
0,159
1,29 /
0,517
1,28 /
2,298
1,32 /
17,3
1,35 /
43,1
1,35 /
325
-
0,0483
1,15 /
0,111
1,16 /
0,012
1,16 /
0,0144
1,17 /
3,61
1,17 /
0,0228
1,18 /
781
0,0031
1,19 /
0,00403
1,18 /
0,00595
1,17 /
0,00529
1,19 /
0,00759
1,19 /
0,00625
1,21 /
0,00638
0,0084
1,31 /
0,0112
1,34 /
0,0142
1,34 /
0,0167
1,33 /
0,0186
1,37 /
0,0216
1,38 /
0,0234
0,0568
1,25 /
0,0847
1,26 /
0,136
1,29 /
0,171
1,28 /
0,226
1,33 /
0,278
1,31 /
0,326
В ячейках таблицы приведены два числа: средняя длина цикла
относительно минимального (принята за 1), и средняя продолжительность
работы алгоритма (в секундах). Алгоритм 2.5 использовался при значениях k,
равных 1, 2 и 3. В алгоритме 2.1 процесс прекращался, если после числа
итераций, равного 20 n , не происходило улучшения рекордного значения.
Таблица 3.4 Среднее количество итераций в процессе решения случайного
примера (точность 5%)
Алгоритмы
n
Линейное
булево
программирование
4
5
6
7
8
9
10
11
12
13
14
1,24
20,6
54,2
185
736
1,98∙103
5,79∙103
1,19∙104
3,08∙104
4,73∙104
1,11∙105
Метод
2.1
13,3
18,4
22,5
26,3
32,4
38,8
39,2
39,6
46,7
47,9
54,7
Метод
2.2
Метод
2.3
Метод
2.4
22,2
47,4
101
184
451
22,2
47,3
101
184
450
20,1
31,7
51,5
79,7
201
1,26∙103
4,69∙103
3,58∙104
1,13∙105
4,75∙105
3,33∙106
1,25∙103
4,70∙103
3,59∙104
1,14∙105
4,75∙105
3,32∙106
893
2,37∙103
1,02∙104
2,37∙104
1,64∙103
1,63∙103
Метод
2.5, k=1
16
25
36
49
64
81
100
121
144
169
196
Метод
2.5, k=2
48
101
186
303
479
695
984
1,34∙103
1,77∙103
2,29∙103
2,91∙103
Метод
2.5, k=3
124
356
841
1,65∙103
3,08∙103
5,18∙103
8,16∙103
1,24∙104
1,81∙104
2,55∙104
3,51∙104
61
15
16
17
1,39∙105
2,67∙105
9,72∙105
56,4 8,53∙106 8,53∙106 8,4∙105
5∙107 3,14∙103
58,7 4,99∙107
1,86∙108
64,7
225 3,59∙103 4,66∙104
256 4,43∙103 6,16∙104
289 5,33∙103 7,85∙104
- Несмотря на то, что стратегия «оставь или забери как можно больше»
не является оптимальной, ее применение при просмотре на один шаг вперед
в среднем дает хороший результат и для n=17 средний маршрут на 21%
длиннее оптимального. Просмотр на два и три шага вперѐд ухудшает
результат и при n=17 средний маршрут на 30-40% длиннее оптимального;
- эвристика 2.4, основанная на методе Прима, дает результат наиболее
близкий к оптимальному. Для n=17 средний маршрут на 17% длиннее
оптимального. Затраты времени, при этом, несущественны и для 10
случайных примеров при n=50 метод 2.4 дал решение, потратив в среднем
951 секунду на пример. Исключением является случай, когда образуется
отрезок с большим количеством пунктов (от 12 пунктов). Пример №1351
(n=17; см. таблицу А.1) иллюстрирует данный случай. Метод 2.4 и метод 2.5
(k=1) дают один и тот же маршрут (рисунок 3.2), но затраты времени по
эвристике 2.4 составляют порядка 77 тыс. секунд или 1,85∙1010 итерации.
Затраты времени по методу 2.5 несущественны. Если исключить данный
пример, то среднее время решения задачи при n=17 алгоритмом 2.4 составит
8,16 секунд или 1,03∙106 итерации. На решение данного примера линейным
булевым программированием уходит порядка 5 секунд (см. рисунок 3.3).
62
5
4
3
2
1
0
-5
-4
-3
-2
-1
0
1
2
3
4
5
-1
-2
-3
-4
-5
Рисунок 3.2. Решение примера №1351 методами 2.4 и 2.5.
63
5
4
3
2
1
0
-5
-4
-3
-2
-1
0
1
2
3
4
5
-1
-2
-3
-4
-5
Рисунок 3.3. Решение примера №1351 через линейное булево
программирование.
- эвристики 2.2 и 2.3 имеют схожие результат и затраты времени. Для
n=17 средний маршрут на 35%-40% длиннее оптимального. В среднем, на
решение задачи уходит до 350 секунд.
- наихудший результат среди эвристик дают случайный поиск (метод
2.1). Для n=17 средний маршрут на 90-95% длиннее оптимального.
64
3.4 Сравнение эффективности эвристик для решения задачи 3
Так как задача является трудоемкой, вычислительный эксперимент
ставился при n=4-8 рассмотрены 33 типа задач (таблица 3.5), в которых были
заданы веса грузов в каждом пункте. Расстояния между пунктами
определяются следующим образом: генерация координат пунктов (x(i), y(i))
(i=1,…,n) аналогично численным экспериментам задачи 2, за базу
принимается точка (0,0), расстояния Ci,j принимаются равными евклидовым
расстояниям между точками. Вместимость ТС принималась равной 3
единицам.
Типы рассмотренных примеров приведены в таблицу 3.5.
Таблица 3.5 Типы примеров для численных экспериментов по задаче 3
Вес груза в пункте
№ n
1
2
3
4
5
6
7
8
1
4 1
-1
1
-1
2
4 2
-1
1
-2
3
4 2
-2
2
-2
4
4 3
-2
1
-2
5
4 3
-2
2
-3
6
4 3
-3
3
-3
7
4 4
-4
3
-3
8
4 4
-4
4
-4
9
5 2
-1
1
-1
-1
10
5 3
-1
1
-1
-2
11
5 3
-2
2
-1
-2
12
5 3
-2
3
-2
-2
13
6 1
1
1
-1
-1
-1
14
6 2
1
1
-2
-1
-1
15
6 2
2
1
-2
-1
-2
16
6 2
2
2
-2
-2
-2
17
7 2
1
1
-1
-1
-1
-1
18
7 2
2
1
-2
-1
-1
-1
19
7 2
2
2
-2
-2
-1
-1
20
8 1
1
1
1
-1
-1
-1
-1
21
8 1
1
1
2
-2
-1
-1
-1
22
8 1
1
2
2
-2
-2
-1
-1
65
23
24
25
26
27
28
29
30
31
32
33
8
8
8
8
8
8
8
8
8
8
8
Для
1
2
2
2
-2
2
2
2
2
-2
1
2
2
3
-1
3
2
2
2
-3
3
3
2
2
-3
3
3
3
2
-3
2
2
2
2
2
3
3
2
2
2
3
3
3
2
2
3
3
3
3
2
3
3
3
3
3
задач всех типов было сгенерировано по
-2
-2
-2
-2
-2
-2
-2
-2
-3
-2
-3
-3
-2
-2
-3
-2
-3
-3
-3
-4
-4
-4
100 примеров. В
-1
-2
-3
-2
-2
-2
-6
-7
-7
-7
-7
каждом
случае применялись описанные алгоритмы. Начиная с 20 типа метод 1.1 не
применялся.
Сводка полученных результатов приведена в таблице 3.6.
Таблица 3.6 Средняя длина маршрута относительно оптимального и среднее
время решения задачи алгоритмами (точность 5%)
тип
задачи
Метод 1.1
1
1 / 0,002
2
1 / 0,0046
3
1 / 0,0189
4
1 / 0,0144
5
1 / 0,0362
6
1 / 0,0695
7
1 / 1,19
8
1 / 13,8
9
1 / 0,0119
10
1 / 0,0314
11
1 / 0,132
12
1 / 0,813
Метод 2.2,
k=2
1,11 /
0,0015
1,14 /
0,0015
1,21 /
0,0012
1,28 /
0,0021
1,22 /
0,0015
1,08 /
0,0016
1,18 /
0,0016
1,12 /
0,0023
1,11 /
0,0029
1,18 /
0,0029
1,24 /
0,0026
1,16 /
0,0027
Алгоритмы
Метод 2.2, Метод 2.3
Метод 2.4
Метод 2.5
k=3
1,06 / 0,0022 1,18 / 0,0005 1,06 / 0,0009 1,06 / 0,0012
1,09 / 0,0021 1,18 / 0,0006 1,04 / 0,0007 1,04 / 0,0029
1,24 / 0,0023 1,60 / 0,001
1,56 / 0,0009 1,26 / 0,0048
1,25 / 0,0016 1,29 / 0,0009 1,38 / 0,001
1,13 / 0,0049
1,23 / 0,0027 1,18 / 0,0005 1,24 / 0,0013 1,09 / 0,01
1,05 / 0,0015 1,11 / 0,0005 1,04 / 0,0059 1,03 / 0,0158
1,07 / 0,0031 1,38 / 0,0004 1,21 / 0,0077 1,09 / 0,0248
1,13 / 0,004
1,14 / 0,0006 1,06 / 0,0274 1,06 / 0,0356
1,06 / 0,0037 1,33 / 0,0012 1,06 / 0,0012 1,06 / 0,0025
1,21 / 0,0044 1,31 / 0,0009 1,31 / 0,0013 1,11 / 0,0057
1,27 / 0,0051 1,28 / 0,0006 1,27 / 0,0013 1,10 / 0,0112
1,19 / 0,0048 1,26 / 0,0009 1,10 / 0,0065 1,09 / 0,019
66
13
1 / 0,0254
14
1 / 0,0997
15
1 / 0,499
16
1 / 2,7
17
1 / 0,229
18
1 / 1,3
19
1 / 5,4
20
21
22
23
24
25
26
27
28
29
30
31
32
33
1,23 /
0,0041
1,29 /
0,0044
1,28 /
0,0046
1,24 /
0,005
1,23 /
0,0063
1,27 /
0,0063
1,28 /
0,0063
1,15 /
0,0086
1,18 /
0,0089
1,20 /
0,0093
1,11 / 0,01
1,08 /
0,0098
1,16 /
0,0095
1,09 /
0,0099
1,08 /
0,0097
1,11 /
0,0092
1,09 /
0,0105
1,08 /
0,0107
1,06 /
0,0105
1,11 /
0,0108
1,17 /
0,0101
1,17 / 0,0088 1,35 / 0,0009 1,07 / 0,0015 1,09 / 0,0037
1,20 / 0,0088 1,47 / 0,0012 1,37 / 0,0013 1,13 / 0,0073
1,29 / 0,0096 1,47 / 0,0009 1,20 / 0,0021 1,13 / 0,012
1,33 / 0,0103 1,51 / 0,001
1,30 / 0,0061 1,31 / 0,0197
1,20 / 0,0152 1,46 / 0,0012 1,30 / 0,0016 1,13 / 0,0077
1,24 / 0,0175 1,56 / 0,0009 1,24 / 0,002
1,16 / 0,013
1,24 / 0,0191 1,59 / 0,0018 1,27 / 0,0062 1,28 / 0,0199
1,13 / 0,0284 1,39 / 0,0016 1,18 / 0,0017 1,07 / 0,0083
1,12 / 0,029
1,33 / 0,0019 1,13 / 0,0023 1,07 / 0,0127
1,15 / 0,0315 1,45 / 0,0019 1,07 / 0,0067 1,14 / 0,0202
1,11 / 0,0316 1,49 / 0,0016 1,23 / 0,0091 1,18 / 0,0264
1,11 / 0,0326 1,53 / 0,0019 1,16 / 0,0253 1,28 / 0,0391
1,16 / 0,0309 1,40 / 0,0015 1,11 / 0,027
1,32 / 0,0382
1,15 / 0,0322 1,44 / 0,0016 1,14 / 0,199
1,37 / 0,051
1,11 / 0,0286 1,45 / 0,002
1,49 / 0,0714
1,34 / 0,317
1,16 / 0,0245 1,28 / 0,0018 1,17 / 1,05
1,74 / 0,0957
1,07 / 0,038
1,29 / 0,0666
1,41 / 0,0017 1,26 / 0,302
1,13 / 0,0341 1,23 / 0,0019 1,06 / 8,5
1,41 / 0,113
1,14 / 0,0291 1,31 / 0,0024 1,16 / 12,5
1,57 / 0,145
1,17 / 0,0271 1,28 / 0,0027 1,11 / 46
1,69 / 0,171
1,26 / 0,0267 1,24 / 0,0017 1,01 / 382
1,85 / 0,196
В ячейках таблицы приведены два числа: средняя длина цикла
относительно минимального (принята за 1), и средняя продолжительность
работы алгоритма (в секундах). Алгоритм 2.2 использовался при двух
значениях k: 2 и 3. В алгоритме 2.5 процесс прекращался, если после числа
67
итераций, равного 20
n
a(i) , не происходило улучшения рекордного
i 0
значения.
- Несмотря на то, что стратегия «оставь или забери как можно больше»
не является оптимальной, ее применение при просмотре на два и три шага
вперед в среднем дает хороший результат. При этом просмотр на три шага
вперед требует больших затрат времени при близком (часто большем)
значении целевой функции.
- Эвристика, основанная на построении минимального остовного
дерева с последующими перестановками положительных и отрицательных
групп, эффективна только для малых весов грузов, что вполне естественно.
При этом с ростом числа пунктов временные затраты становятся очень
большими, в то же время, результат оказывается весьма эффективным.
- Эвристика, основанная на построении кратчайших циклов, быстро
реализуется, решение оказывается средним по качеству.
- При применении алгоритма случайного перебора с ростом числа
пунктов временные затраты быстро возрастают, при этом, полученное
решение весьма не эффективно.
3.5 Сравнение эффективности жадных алгоритмов для решения задачи 3
Для заданного числа пунктов n
- генерируются с помощью датчика случайных чисел целочисленные
величины a(1),…, a(n) из заданного промежутка (см. ниже), принимаем
n 1
a(n)
a(i);
i 1
68
- аналогично генерируются 2n вещественных чисел – координаты
пунктов (x(i),y(i)) (i=1,…,n), за базу принимается точка (0,0), расстояния Ci,j
принимаются равными евклидовым расстояниям между точками.
- Вместимость ТС, S, считается целочисленной и задается случайным
образом в указанном промежутке (см. ниже).
С помощью датчика случайных чисел производилась генерация трех
групп задач:
I: 2 a (i ) 2 , S
5;
II: 5 a (i ) 5 , S
50 ;
III: 50 a (i ) 50 , S
Для каждого n
50 .
4;25 в каждой группе генерировались 100 примеров.
К каждой полученной задаче применялся алгоритм 2.2 при k равном 1,
2, 3 или 4. Длины полученных маршрутов сравниваются c результатом
алгоритма при k=1.
Результаты численных экспериментов приведены в таблице 3.7.
Таблица 3.7 Среднее время решения и средние отношения длины маршрута
алгоритмов (точность 5%)
n
Среднее время решения, с
k=1
k=2
k=3
k=4
Группа задач I
4
0,00047 0,0012 0,0016 0,0030
5
0,0012 0,0019 0,0042 0,0095
6
0,0011 0,0028 0,0089
0,029
7
0,0011 0,0045
0,019
0,074
8
0,0025 0,0068
0,037
0,18
9
0,0026
0,011
0,06
0,33
10 0,0028
0,014
0,10
0,62
11 0,0031
0,020
0,15
1,1
12 0,0031
0,026
0,22
1,8
13 0,0042
0,037
0,33
3,0
Среднее отношение длины
маршрута к длине маршрута,
найденного алгоритмом 2.2 (k=1)
k=1
k=2
k=3
k=4
1
1
1
1
1
1
1
1
1
1
1,03
1,06
1,11
1,09
1,09
1,08
1,10
1,11
1,11
1,09
0,99
1,01
1,04
1,07
1,06
1,07
1,10
1,08
1,09
1,06
0,96
0,97
1,02
1,04
1,03
1,03
1,07
1,05
1,09
1,04
69
14 0,0042
0,046
15 0,0053
0,058
16 0,0053
0,072
17 0,0066
0,092
18 0,0070
0,11
19 0,0073
0,13
20 0,0082
0,16
21 0,0094
0,19
22 0,0079
0,23
23 0,0089
0,26
24
0,011
0,31
25
0,011
0,36
Группа задач II
4
0,00077 0,0042
5
0,0009 0,0088
6
0,0014
0,014
7
0,0010
0,026
8
0,0022
0,040
9
0,0027
0,059
10 0,0027
0,081
11 0,0036
0,11
12 0,0042
0,15
13 0,0046
0,20
14 0,0044
0,26
15 0,0056
0,34
16 0,0051
0,41
17 0,0083
0,53
18 0,0078
0,81
19 0,0070
0,74
20 0,0083
0,87
21
0,011
1,4
22
0,011
1,5
23
0,010
1,6
24
0,012
1,7
25
0,013
2,1
Группа задач III
4
0,00077 0,0014
0,45
0,66
0,84
1,1
1,5
1,8
2,4
3,0
3,8
4,6
5,8
7,0
4,6
7,1
10,0
14,0
19,7
25,5
35,1
46,8
63,4
79,8
102
136
1
1
1
1
1
1
1
1
1
1
1
1
1,12
1,10
1,14
1,10
1,12
1,13
1,11
1,10
1,13
1,12
1,11
1,14
1,08
1,12
1,13
1,11
1,10
1,10
1,07
1,09
1,10
1,09
1,10
1,11
1,07
1,10
1,13
1,08
1,11
1,07
1,08
1,10
1,08
1,10
1,10
1,13
0,010
0,023
0,047
0,095
0,17
0,29
0,41
0,64
0,94
1,4
1,9
2,7
3,4
4,8
7,8
7,4
9,5
15,4
17,6
19,6
22,1
28,6
0,027
0,073
0,17
0,39
0,81
1,6
2,4
4,2
6,7
10,7
16,3
24,0
31,8
49,0
82,3
83,9
114
191
226
267
314
426
1
1
1
1
1
1
1
1
1
1
1
1
1
1
1
1
1
1
1
1
1
1
1,01
1,01
1,01
1,01
1,01
1,01
1,01
1,01
1,01
1,01
1,01
1,01
1,02
1,01
1,01
1,01
1,01
1,01
1,01
1,01
1,01
1,01
1,01
1,01
1,01
1,02
1,01
1,01
1,01
1,01
1,01
1,01
1,02
1,01
1,02
1,01
1,01
1,02
1,02
1,02
1,02
1,02
1,02
1,01
1,01
1,01
1,01
1,01
1,01
1,01
1,02
1,01
1,02
1,02
1,02
1,02
1,03
1,02
1,02
1,02
1,02
1,02
1,02
1,02
1,03
1,02
0,0036
0,0065
1
1,02
1,00
0,97
70
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
0,00093
0,00078
0,002
0,0011
0,0025
0,002
0,0023
0,0035
0,0039
0,0049
0,0060
0,0053
0,0059
0,0067
0,0076
0,0086
0,0085
0,010
0,010
0,010
0,013
0,0027
0,0047
0,0059
0,0129
0,02
0,03
0,04
0,05
0,07
0,08
0,10
0,14
0,16
0,21
0,25
0,31
0,38
0,41
0,51
0,61
0,78
0,0076
0,018
0,031
0,056
0,10
0,16
0,24
0,34
0,58
0,74
0,96
1,4
1,7
2,4
3,0
3,9
5,0
5,7
7,5
9,4
12,5
0,023
0,059
0,12
0,27
0,65
0,97
1,6
2,5
4,8
6,4
9,0
14,0
18,4
28,2
37,6
50,7
69,1
82,5
113
148
208
1
1
1
1
1
1
1
1
1
1
1
1
1
1
1
1
1
1
1
1
1
1,03
1,06
1,03
1,05
1,05
1,03
1,04
1,04
1,04
1,02
1,04
1,05
1,05
1,04
1,07
1,03
1,02
1,06
1,05
1,05
1,03
1,01
1,02
1,01
1,03
1,07
1,03
1,06
1,02
1,05
1,04
1,04
1,05
1,04
1,05
1,06
1,04
1,05
1,07
1,05
1,06
1,04
0,99
1,00
1,01
1,02
1,02
1,03
1,03
1,01
1,03
1,05
1,04
1,03
1,04
1,03
1,07
1,04
1,03
1,07
1,05
1,06
1,04
На основании полученных данных можно сделать следующие выводы:
- во всех группах задач при n>=6 алгоритм 2.2 при k=1 имеет лучший
результат по длине маршрута и затраченному времени (число операций), чем
при других значениях k;
- средняя длина маршрута, полученная при k=2 близка к аналогичному
результату при k=3 и k=4, но временные затраты существенно ниже;
- разница в расстояниях найденных маршрутов, в среднем, находится в
пределах 10%, а у группы задач II – в пределах 1%. С увеличением
количества пунктов эта величина сохраняется;
- группа задач II (значительные веса потребителей при небольшой
вместимости ТС) является самой трудоемкой с точки зрения затрат времени,
что объясняется необходимостью многократного посещения каждого пункта.
71
ЗАКЛЮЧЕНИЕ
1. Сформулированы
математические
модели
поставленных
оптимизационных монономенклатурных задач маршрутизации транспортных
средств:
- задача 1: линейная частично целочисленная модель. Дополнительно
были получены точные оценки решения задачи;
- задача 2: квадратичная булева, линейная целочисленная и линейная
булева модели;
- задача 3: модель, в которой неизвестными являются пары, состоящие
из номера вершины и величины груза. Дополнительно было доказано
существование целочисленного решения задачи при целых исходных
данных;
- задача 4: модель задачи 3 с дополнительными ограничениями.
2. Для задач 1, 2, 3 и 4 разработаны точные алгоритмы решения:
- для задачи 1: решение линейной частично целочисленной задачи;
- для задачи 2: метод ветвей и границ, решение квадратичной булевой
задачи, линейной целочисленной задачи, линейной булевой задачи;
- для задач 3 и 4 в целочисленном случае реализован переборный
алгоритм.
3. Для задач 2 и 3 разработаны эвристические алгоритмы, основанных
на различных методах построения маршрутов.
- для задачи 2: случайный перебор, разбиение маршрута на отрезки в
двух вариантах, на основе остовного дерева Прима, поиск ближайшего
допустимого пункта;
- для задачи 3: поиск ближайшего допустимого пункта со стратегией
«оставь или забери как можно больше», построение двух циклов, на основе
остовного дерева Прима (для целочисленной задачи), случайный перебор
(для целочисленной задачи).
72
4. Предложенные
алгоритмы
программно
реализованы.
Вычислительный эксперимент показал, что:
-в задаче 2 из точных методов наиболее эффективным является
использование модели линейного булева программирования;
-в задаче 2 увеличение вместимости более, чем в 1,8-1,9 раз по
сравнению с минимально допустимой (результат решения задачи 1) не
сокращает длину маршрута;
-при решении задачи 2 наиболее эффективным из предложенных
эвристических алгоритмов является использование алгоритма на основе
построения остовного дерева Прима;
-при решении задачи 3 наиболее эффективным из предложенных
эвристических алгоритмов является использование алгоритма на основе
построения остовного дерева Прима.
73
СПИСОК ИСПОЛЬЗОВАННОЙ ЛИТЕРАТУРЫ
1.
Айзенштат В.С., Кравчук Д.Н. О минимуме линейной формы на
множестве всех полных циклов симметрической группы S.
Кибернетика. 1968. 2:64-66.
2.
Бронштейн Е.М., Гиндуллин Р.В. Об одном классе задач
маршрутизации. Математическое Моделирование. 2010. Том 23.
№6. С. 123-132.
3.
Бронштейн Е.М., Гиндуллин Р.В. Об одной целочисленной задаче
маршрутизации. Логистика и управление цепями поставок. 2013.
№6. С. 85-90.
4.
Бронштейн Е.М., Гиндуллин Р.В. Об одном классе задач
маршрутизации. Информационный бюллетень «XIV Всероссийская
конференция «Математическое программирование и приложения»
(тезисы докладов)». Екатеринбург. ИММ УрО РАН. 2011. С. 156157.
5.
Бронштейн
Е.М.,
оптимизационных
международной
Гиндуллин
задач
конференции
Р.В.
Об
одном
маршрутизации.
«Дискретная
классе
Материалы
оптимизация
и
исследование операций». Новосибирск. 2013. С. 127.
6.
Бронштейн Е.М., Гиндуллин Р.В. Об одном классе задач
маршрутизации.
Научно-технические
ведомости
СПбГПУ.
Информатика, телекоммуникации, управление. 2013. №1(164). С.
63-67.
7.
Бронштейн Е.М., Гиндуллин
Р.В. Оптимизационные задачи
транспортной логистики. Материалы международной научной
конференции "Математическое моделирование, оптимизация и
информационные технологии". Кишинеу. Академия транспорта и
коммуникации. 2012. С. 214-219.
74
8.
Бронштейн Е.М., Гиндуллин Р.В. Точные решения некоторых
оптимизационных задач транспортной логистики. Математическое
моделирование. 2013. Том 25. №11. С. 121-127.
9.
Бронштейн Е.М., Заико Т.А. Детерминированные оптимизационные
задачи транспортной логистики. Автоматика и телемеханика. 2010.
10: 133–147.
10.
Гайков Н.Е. О минимуме линейной формы на циклах. // Известия
АН БССР. Серия физико-математических наук. 1980. 4:128.
11.
Гимади Э.Х. , Шахшнейдер А. В. Приближенные алгоритмы с
оценками для задач маршрутизации на случайных входах с
ограниченным числом клиентов в каждом маршруте. // Автоматика
и телемеханика. 2012. № 2. 126–140.
12.
Гиндуллин Р.В. Об одной задаче транспортной логистики. 5-ая
Всероссийская зимняя школа-семинар аспирантов и молодых
ученых «Актуальные проблемы науки и техники». Уфа. 2010. C. 8184.
13.
Кристофидес Н. Теория графов. Алгоритмический подход. М.: Мир.
1978. 432 с.
14.
Мудров В.И. Один способ решения задачи коммивояжера с
помощью целочисленного линейного программирования. Журнал
вычислительной математики и математической физикию 1963. 6:
1137–1139.
15.
Свидетельство о государственной регистрации программы для ЭВМ
№ 2011615572 «Решение задач транспортной маршрутизации
различными методами» в Реестре программ для ЭВМ от 15 июля
2011 г.
16.
Ченцов А.А., Ченцов А.Г., Ченцов П. А. Экстремальная задача
маршрутизации перемещений с ограничениями и внутренними
потерями. Известия высших учебных заведений. Математика. 2010.
6: 64–81.
75
17.
Aarts E., Korst J. Simulated Annealing and Boltzmann Machines. A
stochastic Approach to Combinatorial Optimization and Neural
Computing // Chichester: John Wiley and Sons. 1989. 272 pages.
18.
Ansari N., Hou E. Computational Intelligence for Optimization. Boston:
Kluwer Academic. 1996. 225 pages.
19.
Applegate D., Bixby R., Chvátal М., Cook W., Helsgaun K. Optimal
Tour
of
Sweden
//
The
Traveling
http://www.tsp.gatech.edu/sweden/index.html
Salesman.
(дата
2010.
URL:
обращения
29.10.2013).
20.
Archetti C., Hertz A., Speranza M.G. A tabu search algorithm for the
split delivery vehicle routing problem. Transportation Science. 2006.
40:64-73.
21.
Archetti C., Mansini R., Speranza M.G.. Complexity and reducibility of
the skip delivery problem. Transportation Science. 2005. 39: 182-187.
22.
Archetti C., Savelsbergh M.W.P., Speranza M.G. An optimization-based
heuristic for the split delivery vehicle routing problem. Transportation
Science. 2008. 42:22-31.
23.
Archetti C., Savelsbergh M.W.P., Speranza M.G. To split or not to split:
That is the question. // Transportation Research E. 2008. 44:114-123.
24.
Archetti C., Savelsbergh M.W.P., Speranza M.G. Worst-case analysis
for split delivery vehicle routing problems.Transportation Science. 2006.
40: 226-234.
25.
Archetti C., Speranza M.G. Vehicle routing in the 1-skip collection
problem. Journal of the Operational Research Society. 2004. 55:717-727.
26.
Baker B.M., Carreto C.A.C. A visual interactive approach to vehicle
routing. Computers and Operations Research. 2003. 30:321–337.
27.
Baker E.K. An exact algorithm for the time-constrained traveling
salesman problem. Operations Research. 1983. 31: 65-73.
76
28.
Baldacci R., Hadjiconstantinou E., Mingozzi A. An Exact Algorithm for
the Capacitated Vehicle Routing Problem Based on a Two-Commodity
Network Flow Formulation. Operations Research. 2004. 52: 723-738.
29.
Ball M., Bodin L., Baldacci R., Mingozzi A. The rollon-rolloff vehicle
routing problem. Transportation Science. 2000. 34: 271-288.
30.
Baptiste S., Oliviera R. C., Zuquete E. A period vehicle routing case
study. European Journal of Operational Research. 2002. 139:220-229.
31.
Barachet L.L. Graphic solution to the traveling-salesman problem.
Operations Research. 1957. 5: 841-845.
32.
Baralia R., Hildago J.I., Perego R. A Hybrid Heuristic for the Traveling
Salesman Problem. IEEE Transactions on Evolutionary Computation.
2001. 5(6):1–41.
33.
Beardwood J., Halton J. H., Hammersley J. M. The shortest path through
many points. Proceedings of the Cambridge Philosophical Society. 1959.
55: 299-327.
34.
Beckmann M., Koopmans T.C. A Note on the Optimal Assignment
Problem // Cowles Commission Discussion Paper: Economics 2053.
Chicago: Cowles Commission for Researchin Economics. 1952. 12
pages.
35.
Belenguer J.M., Mart´ınez M.C., Mota E. A lower bound for the split
delivery vehicle routing problem. Operations Research. 2000. 48, 801–
810.
36.
Bellman R. Combinatorial processes and dynamic programming.
Combinatorial Analysis. Providence: American Mathematical Society.
1960. Pages 217-249.
37.
Beltrami E. J., L. D. Bodin. Networks and vehicle routing for municipal
waste collection. Networks. 1974. 4:65-94.
38.
Berbeglia G., Cordeau J.F. Gribkovskaia I., Laporte G. Static pickup and
delivery problems: A classication scheme and survey // TOP. 2007. 15:131.
77
39.
Bertsimas D.J., Chervi P., Peterson M. Computational Approaches to
Stochastic Vehicle Routing Problems. Transportation Science. 1995.
29:342-352.
40.
Bertsimas D.J., Jaillet P., Odoni A.R. A priori optimization. Operation
Research. 1990. 38:1019-1033.
41.
Bianco L., Mingozzi A., Ricciardelli S. Exact and heuristic procedures
for the traveling salesman problem with precedence constraints, based on
dynamic programming. INFOR. 1994. 32:19–31.
42.
Birkhoff G. Tres observaciones sobre el algebra lineal. Revista Facultad
de Ciencias Exactas // Puras y Aplicadas Universidad Nacional de
Tucuman, Serie A (Matematicasy Fisica Teorica). 1946. 5: 147-151.
43.
Bock F. An algorithm for solving "travelling-salesman" and related
network optimization problems [abstract]. Operations Research. 1958, 6:
897.
44.
Bock F. Mathematical programming solution of traveling salesman
examples. Recent Advances in Mathematical Programming. New York:
McGraw-Hill. 1963. 347 pages.
45.
Brandão J. A new tabu search algorithm for the vehicle routing problem
with backhauls. European Journal of Operational Research. 2006. 173:
540–555.
46.
Bronstein E., Gindullin R. On one class of routing optimization problem.
Second Annual Conference of the EURO Working Group of Vehicle
Routing and Logistics Optimization (7-10 July 2013, Southhampton,
UK). Southhampton. P. 19.
47.
Bullnheimer B., Hartl R. F. Strauss C. Applying the Ant System to the
Vehicle Routing Problem. Paper presented at 2nd International
Conference on Metaheuristics // Sophia-Antipolis. 1997. July 21-24.
48.
Burkard R.E., Deineko V.G., van Dal R., van der Veen J.A.A.,
Woeginger G.J. Well-solvable special cases of the TSP: a survey, SIAM
Review. 1998. 40: 496–546.
78
49.
Burkard R.E., Klinz B., Rudolf R. Perspectives of Monge Properties in
Optimization. Discrete Applied Mathematics. 1996. 70: 95-161.
50.
Campos V., Corberan A., Mota E. A Scatter Search Algorithm for the
Split Delivery Vehicle Routing Problem. Studies in Computational
Intelligence. 2008. 144: 137–152.
51.
Carrabs F., Cordeau J.-F., Laporte G. Variable neighborhood search for
the pickup and delivery traveling salesman problem with LIFO loading.
INFORMS Journal on Computing. 2007. 19: 618–632.
52.
Casco D., Golden B., Wasil E.. Vehicle routing with backhauls: Models,
algorithms and case studies. Vehicle Routing: Methods and Studies.
Amsterdam: Elsevier Science Publishers. 1988. 127– 147.
53.
Çelaa E., Deinekob V., Woegingerc G.J. The x-and-y-axes travelling
salesman problem. European Journal of Operational Research. 2012.
223: 333–345.
54.
Charon I., Hudry O. Applications of the Noising Method to the
Traveling Salesman Problem. European Journal of Operational Research.
2000. 125:266–277.
55.
Chen S., Golden B., Wasil E. The split delivery vehicle routing problem:
Applications, test problems, and computational results // Networks.
2007. 49: 318-329.
56.
Christofides N., Beasley J.E. The period routing problem. Networks.
1984. 14:237–56.
57.
Christofides N., Mingozzi A., Toth P. Exact algorithms for the vehicle
routing problem based on spanning tree and shortest path relaxation.
Mathematical Programming. 1981. 10:255–280.
58.
Christofides N., Mingozzi A., Toth P. The vehicle routing problem.
Combinatorial Optimization. Chichester: Wiley. 1979. pp315–338.
59.
Clarke G., Wright J. Scheduling of vehicles from a central depot to a
number of delivery points. Operations Research. 1964. 12: 568-581.
79
60.
Cordeau J.-F., Gendreau M., Laporte G. A tabu search heuristic for
periodic and multi-depot vehicle routing problems. Networks. 1997. 30:
105-119.
61.
Cordeau J.-F., Laporte G., Røpke S. Recent models and algorithms for
one-to-one pickup and delivery problems // The Vehicle Routing
Problem: Latest Advances and New Challenges. Springer. 2008. Pages
327–357.
62.
Croes G.A. A method for solving traveling-salesman problems.
Operations Research. 1958. 6: 791-812.
63.
Cutler M. Efficient special case algorithms for the N-line planar
traveling salesman problem. 1980. Networks. 10: 183-195.
64.
Dantzig G., Fulkerson R., Johnson S. Solution of a Large Scale
Traveling Salesman Problem. Paper P-510. Santa Monica: The RAND
Corporation, 1954.
65.
Dantzig G.B., Ramser J.H. The Truck Dispatching Problem.
Management Science. 1959. 6: 80-91.
66.
Deif I., Bodin L. Extension of the Clarke and Wright algorithm for
solving the vehicle routing with backhauling. Proceedings of the Babson
Conference on Software Uses in Transportation and Logistics
Management. 1984. pp. 75–96.
67.
Desaulniers G., Desrosiers J., Erdmann A., Solomon M.M., Soumis F.
VRP with pickup and delivery. SIAM Monographs on Discrete
Mathematics and Applications. 2002. 9: 225–242.
68.
Desrochers M., Verhoog T. W. A Matching Based Savings Algorithm
for the Vehicle Routing Problem. Les Cahiers du GERAD G-89-04.
Montréal: École des Hautes Études Commerciales de Montréal. 1989. 19
pages.
69.
Desrosiers J., Dumas Y., Soumis F. A dynamic programming solution of
the large-scale single-vehicle dial-a-ride problem with time windows.
80
American Journal of Mathematical and Management Sciences, 1986.
6:301–325.
70.
Diaby M. The salesman traveling problem: a linear programming
formulation // WSEAS Transactions on Mathematics 2007. 6: 745-754.
71.
Dorigo M. Ant Colonies for the Traveling Salesman Problem. IEEE
Transactions on Evolutionary Computation. 1997. 1:53–66.
72.
Dorigo M. Optimization, Learning and Natural Algorithms. Ph.D.
Thesis. Milano: Politecnico di Milano.1992.
73.
Dror M., Laporte G., Trudeau P. Vehicle routing with split deliveries.
Discrete Applied Mathematics. 1994. 50: 239–254.
74.
Dror M., Trudeau P. Savings by split delivery routing. Transportation
Science. 1989. 23: 141-145.
75.
Dror M., Trudeau P. Split delivery routing. Naval Research Logistics.
1990. 37: 383-402.
76.
Dror M., Trudeau P. Stochastic Vehicle Routing With Modified Savings
Algorithm. European Journal of Operational Reserach. 1986. 23:228235.
77.
Dueck G., Scheurer T. Threshold Accepting: A General Purpose
Optimization Algorithm // Journal of Computational Physics. 1990.
90:161-175.
78.
Eastman W.L. Linear programming with pattern constraints. Ph.D.
Dissertation. Harvard: Harvard University. 1958.
79.
Fejes L. Uber einen geometrischen Satz. Mathematische Zeitschrift.
1940. 46: 83-85.
80.
Few L. The shortest path and the shortest road through n points.
Mathematika. 1955. 2: 141-144.
81.
Fischetti M., Gonzalez J.J.S., Toth P. A branch-and-cut algorithm for the
symmetric
generalized
traveling
salesman
problem.
Operations
Research. 1997. 45: 378-394.
81
82.
Fischetti M., Toth P. An additive bounding procedure for combinatorial
optimization problems. Operations Research. 1989. 37:319–328.
83.
Fisher M. L., Jaikumar R. A Generalized Assignment Heuristic for
Vehicle Routing. Networks. 1981. 11:109-124.
84.
Frizzell P.W., Giffin J.W. The split delivery vehicle scheduling problem
with time windows and grid network distances. Computers & Operations
Research. 1995. 22: 655-667.
85.
Fukasawa R., de Aragao M.P., Reis M., Uchoa E. Robust Branch-andCut-and-Price for the Vehicle Routing Problem. Relatorios de Pesquisa
em Engenharia de Producao RPEP. 2003. 8.
86.
Gamboa D., Rego C., Glover F. Data Structures and Ejection Chains for
Solving Large-Scale Traveling Salesman Problems. European Journal of
Operational Research. 2005. 160:154–171.
87.
Gamboa D., Rego C., Glover F. Implementation Analysis of Efficient
Heuristic Algorithms for the Traveling Salesman Problem. Computers &
Operations Research. 2006. 33:1154–1172.
88.
Gavish B. A note on the formulation of the m-salesman traveling
salesman problem. Management Science. 1976. 22: 704–705.
89.
Gelinas S., Fabrication de Tournees avec Rechargement. Unpublished
Master's Thesis. Montreal: Ecole Polytechnique. 1991.
90.
Gendreau M., Dejax P., Feillet D., Gueguen C. Vehicle routing with time
windows and split deliveries. Technical Report 851. Avignon:
Laboratoire d'Informatique d'Avignon. 2006.
91.
Gerards A.M.H. Matching in Network Models. In Handbooks in
Operations Research and Management Science. Amsterdam: NorthHolland. 1995. Vol. 7. pp. 135-224.
92.
Ghosh M. N. Expected travel among random points in a region. Calcutta
Statistical Association Bulletin. 1949. 2: 83-87.
93.
Giaglis G. M., Minis I., Tatarakis A., Zeimpekis V. Minimizing logistics
risk through real-time vehicle routing and mobile technologies: research
82
to date and future trends. International Journal of Physical Distribution &
Logistics Management, 2004. 34:749–764.
94.
Gillett B. E., Miller L. R. A Heuristic Algorithm for the Vehicle
Dispatch Problem. Operations Research. 1974. 22:340-349.
95.
Gillett B.E., Johnson J.G. Multi-terminal vehicle-dispatch algorithm.
Omega. 1976. 4:711–718.
96.
Glover F. A Template for Scatter Search and Path Relinking. Lecture
Notes in Computer Science. 1997. 1363: 13–54.
97.
Glover F. Future paths for integer programming and links to artificial
intelligence. Computers and Operations Research. 1986. 13:533–549.
98.
Goetschalckx M., Jacobs-Blecha C. The vehicle routing problem with
backhauls. European Journal of Operational Research. 1989. 42: 39–51.
99.
Goetschalckx, M., Jacobs-Blecha, C. The vehicle routing problem with
backhauls: Properties and solution algorithms. Technical Report MHRCTR-88-13 // Athlanta: Georgia Institute of Technology. 1993.
100.
Goldbarg E.F.G., Souza G.R., Goldbarg M.C. Particle Swarm
Optimization for the Traveling Salesman Problem. EVOCOP. 2006.
3906:99–110.
101.
Goldberg D. Genetic Algorithms in Search, Optimization, and Machine
Learning. New York: Addison Wesley Publishing Company Inc. 1989.
432 pages.
102.
Golden B., Baker E., Alfaro J., Schaffer J. The vehicle routing problem
with backhauling: Two approaches // Proceedings of the Twenty-first
Annual Meeting of S.E. TIMS. Myrtle Beach: S.E. TIMS. 1985. pp. 90–
92.
103.
Golden B.L. and Assad A.A., Vehicle routing: Methods and studies //
Studies in Management Science and Systems. Volume 16. Amsterdam:
North-Holland. 1988. 7-45.
104.
Grötschel M. On the symmetric travelling salesman problem: solution of
a 120-city problem. Mathematical Programming Study. 1980. 12: 61-77.
83
105.
Gueguen C. M´ethodes de r´esolution exacte pour les probl`emes de
tourn´ees dev´ehicules. Ph.D. thesis. Paris:´Ecole Centrale. 1999.
106.
Hanne L., Decision Support for Planning of Multimodal Transportation
with Multiple Objectives, Kongens Lyngby: DTU Transport. 2009. 225
pages.
107.
Hannemann M.M., Schwartz A. Implementing weighted b-matching
algorithms: Towards a flexible software design // ACM Journal of
Experimental Algorithmics. 1999. 4:7.
108.
Heller I. Geometric characterization of cyclic permutations. Bulletin of
the American Mathematical Society. 1955. 61: 227.
109.
Heller I. Neighbor relations on the convex of cyclic permutations.
Bulletin of the American Mathematical Society. 1955. 61: 440.
110.
Heller I. Neighbor relations on the convex of cyclic permutations.
Pacific Journal of Mathematics.1956. 6: 467-477.
111.
Heller I. On the problem of shortest path between points. I // Bulletin of
the American Mathematical Society. 1953. 59: 551.
112.
Heller I. On the problem of shortest path between points. II // Bulletin of
the American Mathematical Society, 1953. 59: 551-552.
113.
Heller I. On the travelling salesman's problem. Proceedings of the
Second Symposium in Linear Programming. Washington, D.C.: National
Bureau of Standards, U.S.Department of Commerce. 1956. Pp.643-665.
114.
Hong S. A linear programming approach for the traveling salesman
problem. Ph.D. Thesis. Baltimore: The Johns Hopkins University. 1972.
115.
Jaillet P. A priori solution of a travelling salesman problem in which a
random subset of customers are visited. Operations Research. 1988. 36:
929-936.
116.
Jessen R. J. Statistical Investigation of a Sample Survey for Obtaining
Farm. Facts Research Bulletin 304. Ames: Iowa State College of
Agriculture and Mechanic Arts. 1942.
84
117.
Jin M., Liu K., Bowden R.O. A two-stage algorithm with valid
inequalities for the split delivery vehicle routing problem. International
Journal of Production Economics. 2007. 105: 228–242.
118.
Jonathan F. Bard, Liu Huang, Patrick J., Moshe Dror, A Decomposition
Approach to the Inventory Routing Problem with Satellite Facilities.
Transportation Science. 1998 . 32: 189-203.
119.
Kalantari B., Hill A.V., Arora S.R. An algorithm for the traveling
salesman problem with pickup and delivery customers. European Journal
of Operational Research. 1985. 22:377-386.
120.
Karg R.L., Thompson G.L. A heuristic approach to solving travelling
salesman problems. Management Science. 1964. 10: 225-248.
121.
Kuhn H.W. On certain convex polyhedra. Bulletin of the American
Mathematical Society. 1955. 61: 557-558.
122.
Kytöjoki J., Nuortio T., Bräysy O., Gendreau M. An efficient variable
neighborhood search heuristic for very large scale vehicle routing
problems. Computers & Operations Research, 2007. 34:2743–2757.
123.
Lambert F. The traveling-salesman problem. Cahiers du Centre de
Recherche Opérationelle. 1960. 2: 180-191.
124.
Land A. The solution of some 100-city travelling salesman problems.
Technical Report // London: London School of Economics. 1979
125.
Landrieu A., Mati Y., and Binder Z. A tabu search heuristic for the
single vehicle pickup and delivery problem with time windows. Journal
of Intelligent Manufacturing. 2001. 12:497-508
126.
Laporte G., Louveau F. Formulations and Bounds for the Stochastic
Capacicated Vehicle Routing Problem With Uncertain Supplies. Report
G-87-23, Montreal: Ecole Hautes Etudes Commerciale. 1987.
127.
Laporte G., Louveau F., Mercure H. Models and Exact Solutions for a
Class of Stochastic Location-Routing Problems. Report G-87-23,
Montreal: Ecole Hautes Etudes Commerciale. 1987.
85
128.
Laporte G., Louveaux F.V., Mercure H. Models and exact solutions for a
class of stochastic location-routing problems. European Journal of
Operational Research. 1989. 39:71-78.
129.
Laporte G., Louveaux F.V., Mercure H. The vehicle routing problem
with stochastic travel times. Transportation Science. 1992. 26:161-170.
130.
Laporte G., Mercure H., Nobert Y. An exact algorithm for the
asymmetrical capacitated vehicle routing problem. Networks. 1986. 16:
33-46.
131.
Lawler E.L., Wood D.E. Branch-and-bound methods: a survey //
Operations Research. 1966. 14: 699-719.
132.
Lee C.G., Epelman M.A., White III C.C., Bozer Y.A. A shortest path
approach to the multiple-vehicle routing problem with split pick-ups.
Transportation Research B. 2006. 40: 265–284.
133.
Li X, Tian P., Hua J., Zhong N. A Hybrid Discrete Particle Swarm
Optimization for the Traveling Salesman Problem. SEAL. 2006.
4247:181-188.
134.
Lin S. Computer solutions of the traveling salesman problem. The Bell
System Technical Journal. 1965. 44: 2245-2269.
135.
Little J.D.C., Murty K.G., Sweeney D.W., Karel C. An algorithm for the
traveling salesman problem. Operations Research. 1964. 11: 972-989.
136.
Liu K. A study on the split delivery vehicle routing problem. PhD thesis,
Starkville: Mississippi State University. 2005.
137.
M.M. Flood, The traveling-salesman problem, Operations Research 4
61-75
138.
Mahalanobis P. C. A sample survey of the acreage under jute in Bengal.
Sankhya. 1940. 4: 511-530.
139.
Malek M., Huruswamy M., Owens H., Pandya M. Serial and parallel
search techniques for the traveling salesman problem. Annual Operation
Research. 1989. 21: 59–84.
86
140.
Marinakis Y., Migdalas A., Pardalos P.M. Expanding Neighborhood
GRASP
for
the
Traveling
Salesman
Problem.
Computational
Optimization and Applications. 2005. 32:231–257.
141.
Marks E. S. A lower bound for the expected travel among m random
points. The Annals of Mathematical Statistics. 1948. 19: 419-422.
142.
Martin G.T., Solving the traveling salesman problem by integer linear
programming. Technical report. // New York: C-E-I-R. 1966.
143.
Martinovic G., Aleksi I., Baumgartner A. Single-Commodity Vehicle
Routing Problem with Pickup and Delivery Service. Mathematical
Problems in Engineering, 2008. 2008: 17 pages.
144.
Matthus F. Tourenplanung - Verfahren zur Einsatzdisposition von
Fuhrparks // Darmstadt: S.Toeche-Mittler Verlag. 1978. 244 seiten.
145.
Menger K.
Das botenproblem. Ergebnisse eines Mathematischen
Kolloquiums. 1932. 2: 11-12.
146.
Menger K. Ein Theorem über die Bogenlange. Mathematischnaturwissenschaftliche. 1928. 65: 264-266.
147.
Menger K. On shortest polygonal approximations to a curve. Reports of
a Mathematical Colloquium. 1940. 2: 33-38.
148.
Menger K. Uber die neue Defnition der Bogenlange. Mathematischnaturwissenschaftliche. 1929. 66: 23-24.
149.
Meulemeester L. De, Laporte G., Louveaux F.V., Semet F. Optimal
sequencing of skip collections and deliveries. Journal of the Operational
Research Society. 1997. 48: 57-64.
150.
Milgram A.N. On shortest paths through a set. Reports of a
Mathematical Colloquium. 1940. 2:39-44.
151.
Miller C.E., Tucker A.W., Zemlin R.A. Integer programming
formulation of traveling salesman problems. Journal of the Association
for Computing Machinery. 1960. 7:326-329.
152.
Mladenovic N., Hansen P. Variable Neighborhood Search. Computers &
Operations Research. 1997. 24:1097–1100.
87
153.
Morton G., Land A., A contribution to the `travelling-salesman' problem.
Journal of the Royal Statistical Society Series B. 1955. 17: 185-194.
154.
Mueller-Merbach H. Drei neue methoden zur lösung des travelling
salesman problems, teil 1 // Ablauf und Planungsforschung. 1966. 7: 3246.
155.
Mueller-Merbach H. Drei neue methoden zur lösung des travelling
salesman problems, teil 2 // Ablauf und Planungsforschung 1966. 7: 7891.
156.
Mueller-Merbach H. Zweimal travelling Salesman. DGOR-Bulletin.
1983. 25: 12-13.
157.
Mullaseril P.A., Dror M., Leung J. Split-delivery routing in livestock
feed distribution. Journal of the Operational Research Society. 1997. 48:
107-116.
158.
Norman R.Z. On the convex polyhedra of the symmetric traveling
salesman problem. Bulletin of the American Mathematical Society.
1955. 61:559.
159.
Nowak M., Ergun O., White C.C. Pickup and delivery with split loads.
Submitted for publication. Transportation Science. 2008. 42: 32-43.
160.
Nowak M.A. The pickup and delivery problem with split loads.
PhDthesis. Atlanta:Georgia Institute of Technology. 2005.
161.
Ombuki B., Hanshar F. An effective genetic algorithm for the multidepot vehicle routing problem. Technical report // Ontario: Brock
University. 2004.
162.
Osman I.H. Metastrategy simulated annealing and tabu search
algorithms for the vehicle routing problem. Annals of Operations
Research. 1993. 41:421–451.
163.
Pankratz G. A grouping genetic algorithm for the pickup and delivery
problem with time windows. Operations Research Spectrum. 2005.
27:21–41.
88
164.
Parragh S., Doerner K., Hartl R. A survey on pickup and delivery
problems. Part I: Transportations between customers and depot // Journal
fur Betriebswirtschaft. 2008. 58: 21-51.
165.
Parragh S., Doerner K., Hartl R. A survey on pickup and delivery
problems. Part II: Transportations between customers and depot //
Journal fur Betriebswirtschaft. 2008. 58: 21-51.
166.
Parragh S.N., Doerner K.F., Hartl R.F. A survey on pickup and delivery
models, part I // Journal fur Betriebswirtschaft. 2008. 58: 21–51.
167.
Picard J. C., Queyranne M. The time-dependent travelling salesman
problem and its application to the tardiness in one-machine scheduling.
Operations Research. 1978, V.26, P.86–110.
168.
Potvin J.Y. Genetic Algorithms for the Traveling Salesman Problem.
Annual Operation Research. 1995. 63:339–370.
169.
Potvin J.Y., Rousseau J.M. A Parallel Route Building Algorithm for the
Vehicle Routing and Scheduling Problem with Time Windows.
European Journal of Operational Research. 1993. 66: 331−340.
170.
Potvin J.Y., Rousseau J.M. An Exchange Heuristic for Routeing
Problems with Time Windows. Journal of the Operational Research
Society . 1995. 46: 1433 −1446.
171.
Raymond T.C. Heuristic algorithm for the traveling-salesman problem.
IBM Journal of Research and Development. 1969. 13: 400-407.
172.
Reiter S., Sherman G. Discrete optimizing. SIAM Journal on Applied
Mathematics. 1965. 13:864-889.
173.
Renaud J., Boctor F.F., Laporte G. Perturbation heuristics for the pickup
and delivery traveling salesman problem. Computers & Operations
Research. 2002. 29:1129–1141.
174.
Renaud J., Laporte G., Boctor F. F. A tabu search heuristic for the multidepot vehicle routing problem. Computers & Operations Research. 1996.
23:229–235.
89
175.
Robacker J.T. Some Experiments on the Traveling-Salesman Problem.
Research Memorandum RM-1521. Santa Monica: The RAND
Corporation. 1955.
176.
Roberts S.M., Flores B. An engineering approach to the traveling
salesman problem. Management Science. 1966. 13: 269-288.
177.
Robinson J. On the Hamiltonian Game (A Traveling Salesman Problem).
Research
Memorandum
RM-303.
Santa
Monica:
The
RAND
Corporation. 1949. 10 pages.
178.
Ronald S. Routing and Scheduling Problems. Practical Handbook of
Genetic Algorithms. New York: CRC Press. 1995. Pages 367–430.
179.
Rossman M. J., Twery R. J. A solution to the travelling salesman
problem by combinatorial programming. Operations Research. 1958.
6:897.
180.
Russell R.A., Igo W. An assignment routing problem. Network. 1979. 9:
1-17.
181.
Ryan D. M., Hjorring C. and Glover F. Extensions of the Petal Method
for Vehicle Routing. Journal of the Operational Research Society. 1993.
44:289-296.
182.
Sanders D. On Extreme Circuits, Ph.D. thesis, New York: City
University of New York. 1968.
183.
Scheuerer
S.
Neue
Tabusuche-Heuristiken
fur
die
logistische
Tourenplanung bei restringierendem Anhangereinsatz, mehreren Depots
und
Planungsperioden
//
PhD
thesis.
Regensburg:
Universitat
Regensburg. 2004.
184.
Schrijver A. On the History of Combinatorial Optimization (till 1960).
Handbooks in Operations Research and Management Science: Discrete
Optimization. Amsterdam: Elsevier. 2005. pp. 1-68
185.
Shapiro D. Algorithms for the solution of the optimal cost traveling
salesman problem. Sc.D. Thesis, St. Louis: Washington University.
1966.
90
186.
Sierksma G., Tijssen G.A. Routing helicopters for crew exchanges on
off-shore locations. Annals of Operations Research. 1998. 76: 261-286.
187.
Solomon M.M. Algorithms for the Vehicle Routing Problem with Time
Windows. Transportation Science. 1995. 29:156-166.
188.
Solomon M.M. Algorithms for the Vehicle Routing and Scheduling
Problems with Time Window Constraints. Operations Research. 1987.
35: 254−265.
189.
Stewart
W.R.Jr.,
Golden
B.L.
Stochastic
vehicle
routing:
A
comprehensive approach // European Journal of Operational Research.
1983. 14:371-385.
190.
Taillard É.D. Parallel iterative search methods for vehicle routing
problems. Networks. 1993. 23:661–673.
191.
Tan C.C.R., Beasley J. E. A heuristic algorithm for the period vehicle
routing problem. Omega. 1984. 12:497-504.
192.
Teodorovic D., Pavkovic G. A simulated annealing technique approach
to the vehicle routing problem in the case of stochastic demand.
Transportation Planning and Technology. 1992. 16:261–273.
193.
Thanghia S.R., Salhi S. Genetic clustering: An adaptive heuristic for the
multidepot vehicle routing problem // Applied Artificial Intelligence.
2001. 15:361–383.
194.
Thangiah S. R., Nygard K. E., Juell P. L. Gideon: A genetic algorithm
system for vehicle routing with time windows // Proceedings of the
Seventh Conference on Artificial Intelligence Applications. Miami:
IEEE Computer Society Press. 1991. Pages 322–325.
195.
Thangiah S.R. Vehicle Routing with Time Windows using Genetic
Algorithms. Technical Report SRU-CpSc-TR-93-23. Slippery Rock:
Computer Science Department, Slippery Rock University. 1993.
196.
Thompson P. M., Psaraftis H. N. Cyclic Transfer Algorithms for the
Multivehicle Routing and Scheduling Problems. Operations Research.
1993. 41:935-946.
91
197.
Tillman F.A. The multiple terminal delivery problem with probabilistic
demands. Transportation Science. 1969. 3:192–204.
198.
Van Breedam A. An Analysis of the Behavior of Heuristics for the
Vehicle Routing Problem for a Selection of Problems with VehicleRelated, Customer-Related, and Time-Related Constraints. Ph.D.
dissertation // Antwerp:University of Antwerp. 1994
199.
Van der Bruggen L.J.J., Lenstra J.K., Schuur P.C. Variable-depth search
for the single-vehicle pickup and delivery problem with time windows.
Transportation Science. 1993. 27:298–311.
200.
Verblunsky S. On the shortest path through a number of points.
Proceedings of the American Mathematical Society. 1951. 2: 904-913.
201.
Weuthen H.-K. Tourenplanung - Losungsverfahren fur Mehrdepot –
Probleme // PhD thesis. Universitat Karlsruhe TH. 1983.
202.
Wilck IV J., Cavalier T. A Construction Heuristic for the Split Delivery
Vehicle Routing Problem. American Journal of Operations Research.
2012. 2: 153-162.
203.
Willard J.A.G. Vehicle routing using r-optimal tabu search. MSc thesis.
London: Management School, Imperial College. 1989.
204.
Wren A. and Holliday A. Computer scheduling of vehicles from one or
more depots to a number of delivery points. Journal of the Operational
Research Society. 1972. 23:333–344.
205.
Xie M., Miyawaki T., De Jong K.A. Solving the Multi-Depot Vehicle
Routing Problem using Ant Colony Optimization and Re-Assignment //
Applied Simulation and Modelling / 777: Artificial Intelligence and Soft
Computing, June 25 – 27, 2012, Napoli. Calgary: ACTA Press. 2012.
777-007.
206.
Yano C.A., Chan T.J., Richter L., Culter T., Murty K.G., McGettigan D.
Vehicle Routing at Quality Stores. Interfaces. 1987. 17: 52-63.
92
ПРИЛОЖЕНИЕ А.
Таблица А.1 Число итераций разных алгоритмов при решении примеров задачи 2
n
№
Количество итерации, затраченное на решение примера, с
Линейное
целочисленное
программирование
Квадратичное
булево
программирование
Метод
ветвей и
границ
Линейное
булево
программирование
Метод
2.1
(случайный
поиск)
Метод
2.2
(отрезки
1)
Метод
2.3
(отрезки
2)
Метод
2.4
(остовное
дерево
Прима)
Метод
2.5
(жадный
поиск),
k=1
Метод
2.5
(жадный
поиск),
k=2
Метод
2.5
(жадный
поиск),
k=3
4
1
237
21
17
3
13
29
32
32
16
41
109
4
2
88
10
17
0
14
29
32
32
16
50
133
4
3
51
17
12
0
15
16
16
16
16
41
134
4
4
44
20
14
5
19
16
16
16
16
42
112
4
5
71
10
17
2
10
29
32
32
16
53
109
4
6
79
19
13
0
11
16
16
16
16
53
115
4
7
166
10
16
3
12
29
32
32
16
45
113
4
8
134
14
13
0
12
16
16
16
16
45
134
4
9
0
19
14
6
11
16
16
16
16
43
128
4
10
123
14
13
0
17
16
16
16
16
46
127
4
11
56
16
13
0
16
16
16
7
16
58
142
4
12
59
17
13
0
19
16
16
7
16
40
110
4
13
69
19
13
0
10
16
16
16
16
42
127
4
14
169
14
17
3
19
29
32
32
16
54
109
93
4
15
324
17
13
0
11
16
16
7
16
52
138
4
16
46
17
17
3
11
29
32
32
16
53
133
4
17
349
16
11
0
13
16
16
16
16
45
111
4
18
48
15
13
0
14
16
16
16
16
45
115
4
19
52
15
13
0
10
16
16
16
16
52
115
4
20
370
21
17
0
10
29
32
32
16
53
137
4
21
53
13
10
0
10
29
32
32
16
50
114
4
22
49
10
17
3
15
29
32
32
16
45
125
4
23
260
10
17
1
12
29
32
32
16
45
113
4
24
239
14
17
0
11
29
32
32
16
45
137
4
25
54
19
17
3
12
29
32
32
16
45
113
4
26
293
19
17
3
16
29
32
32
16
50
125
4
27
591
15
10
0
13
29
32
32
16
50
119
4
28
142
20
14
5
10
16
16
7
16
55
128
4
29
44
16
16
0
18
29
32
32
16
45
125
4
30
114
19
17
3
15
29
32
32
16
45
125
4
31
0
18
10
0
15
29
32
32
16
49
119
4
32
387
13
13
0
11
16
16
16
16
45
127
4
33
47
10
17
0
15
29
32
32
16
53
137
4
34
81
18
17
0
16
29
32
32
16
45
133
4
35
50
15
13
0
11
16
16
16
16
53
115
4
36
282
16
13
0
11
16
16
7
16
44
111
4
37
361
13
15
0
19
29
32
32
16
45
113
4
38
70
12
17
0
15
29
32
32
16
50
137
4
39
53
14
17
3
11
29
32
32
16
45
113
4
40
39
10
17
1
12
29
32
32
16
50
133
4
41
336
13
17
2
18
29
32
32
16
53
113
4
42
47
19
14
6
14
16
16
16
16
47
113
94
4
43
261
16
13
0
13
16
16
16
16
47
128
4
44
120
19
17
3
12
29
32
32
16
41
133
4
45
216
20
13
0
14
16
16
7
16
40
110
4
46
108
10
17
0
19
29
32
32
16
54
137
4
47
223
19
14
6
10
16
16
16
16
53
136
4
48
105
13
10
0
12
29
32
32
16
47
118
4
49
82
20
14
6
14
16
16
7
16
48
117
4
50
229
18
13
0
11
16
16
16
16
46
127
4
51
0
10
16
0
14
29
32
32
16
45
125
4
52
0
19
17
0
10
29
32
32
16
53
109
4
53
97
10
16
0
18
29
32
32
16
45
125
4
54
86
15
13
0
10
16
16
7
16
52
135
4
55
195
17
13
0
13
16
16
16
16
51
134
4
56
70
17
13
0
17
16
16
7
16
42
114
4
57
41
16
13
0
13
16
16
7
16
53
138
4
58
87
15
13
0
11
16
16
16
16
53
142
4
59
646
24
13
0
10
16
16
7
16
52
138
4
60
103
14
17
0
15
29
32
32
16
45
109
4
61
82
10
17
1
10
29
32
32
16
54
137
4
62
40
14
10
0
10
29
32
32
16
49
119
4
63
33
10
17
0
11
29
32
32
16
54
137
4
64
212
25
13
0
10
16
16
7
16
40
135
4
65
41
10
17
0
10
29
32
32
16
45
109
4
66
79
19
13
0
12
16
16
7
16
44
111
4
67
465
10
17
2
24
29
32
32
16
53
133
4
68
48
13
17
0
13
29
32
32
16
41
137
4
69
213
10
17
2
16
29
32
32
16
50
133
4
70
227
14
13
0
10
16
16
7
16
44
134
95
4
71
69
21
14
5
16
16
16
16
16
46
128
4
72
99
14
13
0
11
16
16
7
16
52
114
4
73
101
14
13
0
13
16
16
16
16
48
134
4
74
169
17
13
0
14
16
16
7
16
55
136
4
75
205
17
10
0
16
29
32
32
16
49
114
4
76
156
16
13
0
11
16
16
16
16
46
127
4
77
252
10
9
0
20
29
32
32
16
49
119
4
78
187
10
10
0
22
29
32
32
16
44
114
4
79
31
16
13
0
12
16
16
7
16
40
115
4
80
66
16
13
0
12
16
16
16
16
50
135
4
81
70
10
17
0
11
29
32
32
16
54
137
4
82
178
20
14
5
18
16
16
7
16
53
113
4
83
41
10
10
0
12
29
32
32
16
49
114
4
84
165
21
13
0
11
16
16
16
16
41
111
4
85
391
18
13
0
12
16
16
7
16
46
134
4
86
51
16
12
0
14
16
16
16
16
46
111
4
87
76
18
13
0
11
16
16
16
16
53
135
4
88
159
18
17
3
10
29
32
32
16
41
125
4
89
60
19
14
7
15
16
16
16
16
50
138
4
90
51
21
13
0
12
16
16
16
16
45
127
4
91
54
15
13
0
11
16
16
16
16
47
115
4
92
42
22
14
6
12
16
16
7
16
54
139
4
93
64
14
17
0
19
29
32
32
16
53
133
4
94
33
16
13
0
10
16
16
7
16
47
116
4
95
209
25
14
7
11
16
16
7
16
54
139
4
96
0
19
17
0
12
29
32
32
16
41
109
4
97
228
21
17
3
15
29
32
32
16
45
109
4
98
125
12
17
0
20
29
32
32
16
45
109
96
4
99
67
20
14
6
10
16
16
7
16
56
137
4
100
53
18
14
7
11
16
16
7
16
49
117
5
101
2941
127
38
18
17
39
42
12
25
104
344
5
102
165
80
64
22
27
84
85
85
25
99
400
5
103
1757
107
50
32
12
39
42
42
25
112
364
5
104
1878
91
63
22
13
84
85
85
25
114
395
5
105
57
101
43
24
13
39
42
42
25
96
311
5
106
195
150
51
17
13
39
42
12
25
109
401
5
107
3940
126
39
17
18
39
42
12
25
104
345
5
108
1286
125
38
20
14
39
42
12
25
108
398
5
109
1213
133
42
22
15
39
42
12
25
104
344
5
110
1094
68
50
9
13
39
42
12
25
108
396
5
111
195
88
66
24
16
84
85
85
25
88
385
5
112
552
110
51
23
15
39
42
12
25
112
392
5
113
356
74
49
28
12
39
42
42
25
81
333
5
114
1642
150
46
21
18
39
42
12
25
112
365
5
115
366
126
49
23
15
39
42
12
25
101
298
5
116
55
77
51
10
24
39
42
12
25
111
392
5
117
494
82
37
14
29
39
42
42
25
89
336
5
118
1277
102
41
20
17
39
42
12
25
98
401
5
119
1806
143
43
19
19
39
42
12
25
96
337
5
120
709
127
52
23
15
39
42
12
25
96
334
5
121
1940
59
35
9
15
39
42
42
25
98
323
5
122
539
155
55
27
18
39
42
12
25
108
340
5
123
6894
62
50
10
22
39
42
42
25
94
353
5
124
65
98
43
25
22
39
42
42
25
116
384
5
125
3363
104
38
15
32
38
41
12
25
80
302
5
126
61
94
66
18
21
83
85
85
25
111
395
97
5
127
1500
83
51
17
25
39
42
12
25
108
397
5
128
2131
89
48
14
15
39
42
12
25
111
376
5
129
1056
83
51
16
17
39
42
12
25
80
296
5
130
1787
156
51
24
12
39
42
42
25
96
386
5
131
864
142
49
27
22
39
42
42
25
97
364
5
132
783
87
53
26
16
83
85
85
25
98
325
5
133
290
90
66
27
25
82
85
85
25
88
391
5
134
446
122
52
27
15
39
42
42
25
115
389
5
135
4293
56
24
17
20
84
85
85
25
101
347
5
136
1175
91
49
28
14
39
42
12
25
101
338
5
137
245
139
51
28
16
39
42
12
25
112
392
5
138
227
99
40
27
22
39
42
12
25
95
307
5
139
1503
65
50
21
26
39
42
12
25
80
296
5
140
3602
108
38
18
12
39
42
12
25
84
302
5
141
123
135
49
17
22
39
42
12
25
95
332
5
142
1114
162
48
35
21
39
42
42
25
118
333
5
143
605
137
38
16
18
39
42
12
25
80
356
5
144
935
104
51
21
19
39
42
12
25
96
389
5
145
705
108
39
39
19
39
42
12
25
92
306
5
146
2189
107
52
17
20
39
42
12
25
110
377
5
147
4285
80
65
15
13
83
85
85
25
83
305
5
148
1262
90
65
0
24
82
85
85
25
111
305
5
149
328
92
39
21
14
39
42
12
25
97
336
5
150
227
121
43
22
14
39
42
12
25
102
350
5
151
3005
176
53
42
13
39
42
42
25
102
367
5
152
3756
129
41
31
20
39
42
12
25
105
390
5
153
1559
140
49
20
28
39
42
12
25
110
328
5
154
75
114
42
23
22
39
42
12
25
90
305
98
5
155
1562
86
34
20
19
39
42
12
25
82
297
5
156
59
156
51
20
19
39
42
12
25
112
357
5
157
1496
80
38
13
16
37
40
40
25
116
341
5
158
1965
103
41
19
21
39
42
12
25
96
386
5
159
635
121
46
21
13
39
42
42
25
111
356
5
160
1734
97
66
29
21
85
85
85
25
111
391
5
161
280
154
34
20
14
39
42
12
25
86
301
5
162
1682
79
32
15
13
39
42
42
25
104
340
5
163
358
131
50
21
13
39
42
12
25
102
397
5
164
117
130
41
14
26
39
42
42
25
102
366
5
165
1286
86
47
14
19
39
42
42
25
106
395
5
166
3025
124
51
15
21
39
42
12
25
96
333
5
167
330
91
50
17
13
39
42
42
25
104
303
5
168
2259
169
40
20
16
39
42
12
25
101
306
5
169
3373
95
43
20
12
39
42
42
25
108
350
5
170
343
76
50
9
15
39
42
12
25
92
301
5
171
903
83
28
20
14
85
85
85
25
106
353
5
172
535
85
66
22
25
83
85
85
25
115
401
5
173
830
106
38
14
12
39
42
12
25
110
392
5
174
52
85
62
11
33
85
85
85
25
98
325
5
175
1339
116
43
34
16
39
42
12
25
109
403
5
176
1842
106
55
27
25
39
42
12
25
112
378
5
177
51
82
66
21
12
84
85
85
25
83
406
5
178
3436
99
39
27
18
39
42
12
25
115
394
5
179
809
153
51
29
20
39
42
12
25
108
397
5
180
481
59
48
12
23
39
42
42
25
103
363
5
181
2580
107
42
29
31
39
42
12
25
114
341
5
182
1479
98
38
21
13
39
42
12
25
98
409
99
5
183
392
74
51
10
26
39
42
12
25
111
387
5
184
3492
111
53
21
36
39
42
42
25
98
336
5
185
830
143
46
27
19
39
42
42
25
106
368
5
186
751
127
41
30
20
39
42
12
25
103
400
5
187
5253
88
38
16
13
39
42
42
25
104
336
5
188
712
86
46
24
13
80
85
85
25
115
366
5
189
1542
113
44
25
20
39
42
12
25
112
399
5
190
321
94
64
0
26
83
85
85
25
88
325
5
191
2828
74
49
10
13
39
42
12
25
111
391
5
192
95
102
55
31
22
39
42
12
25
120
369
5
193
61
104
41
17
12
39
42
12
25
84
337
5
194
2023
108
52
31
17
39
42
12
25
112
402
5
195
251
94
63
19
17
82
85
85
25
99
400
5
196
79
117
38
10
25
39
42
12
25
94
314
5
197
2024
142
43
22
13
39
42
42
25
84
301
5
198
2622
68
60
23
12
82
85
85
25
93
330
5
199
6734
124
38
30
13
39
42
12
25
106
371
5
200
289
69
62
11
19
85
85
85
25
83
335
6
201
30022
936
170
0
18
78
84
18
36
181
828
6
202
2758
545
245
38
14
98
101
101
36
186
780
6
203
229
871
226
56
32
101
101
34
36
198
931
6
204
1207
967
187
58
25
78
84
18
36
199
950
6
205
2626
806
257
49
17
97
101
101
36
187
856
6
206
5744
991
145
51
20
98
98
34
36
184
890
6
207
33275
1163
226
55
16
100
101
34
36
179
936
6
208
7863
935
163
50
15
78
84
84
36
165
781
6
209
30552
1240
196
63
28
78
84
18
36
201
886
6
210
16039
1037
184
95
32
78
84
18
36
201
901
100
6
211
5400
666
270
0
20
215
193
193
36
209
940
6
212
46128
998
115
0
22
78
84
18
36
178
782
6
213
5647
881
238
54
29
99
101
34
36
203
880
6
214
4579
592
218
49
27
97
100
18
36
208
834
6
215
9077
926
223
83
21
101
101
34
36
186
863
6
216
15835
871
192
48
18
99
99
34
36
210
943
6
217
113
713
214
37
17
100
101
34
36
157
774
6
218
734
759
141
75
21
68
74
18
36
178
936
6
219
7894
973
204
93
26
78
84
18
36
202
901
6
220
71174
730
147
50
30
97
99
101
36
182
804
6
221
8484
678
160
42
19
98
101
34
36
167
779
6
222
2552
783
114
72
26
100
101
34
36
195
825
6
223
9280
948
201
110
24
18
18
18
36
199
927
6
224
7112
1067
206
89
25
98
101
34
36
203
901
6
225
186607
1114
192
0
25
78
84
18
36
179
789
6
226
4325
669
303
32
14
218
193
193
36
213
947
6
227
2589
694
307
32
25
217
193
193
36
192
898
6
228
423
578
232
24
19
201
193
193
36
193
916
6
229
10008
905
177
61
30
78
84
9
36
167
813
6
230
4353
905
165
43
26
78
84
18
36
197
832
6
231
22709
1346
187
98
19
78
84
9
36
213
933
6
232
22404
992
253
92
14
96
100
101
36
202
893
6
233
112
678
156
101
18
98
101
34
36
171
845
6
234
6911
622
260
42
24
194
193
193
36
199
932
6
235
68524
1036
172
80
26
78
84
18
36
164
830
6
236
3778
1000
198
34
29
78
84
18
36
156
699
6
237
4980
507
219
39
27
101
101
34
36
206
822
6
238
4370
798
146
61
23
18
18
9
36
173
809
101
6
239
8505
901
214
0
24
97
101
34
36
152
739
6
240
3971
1087
204
72
22
78
84
18
36
171
870
6
241
106
1107
207
49
14
78
84
18
36
205
876
6
242
5630
535
268
37
24
229
193
193
36
209
920
6
243
105
993
178
0
27
78
84
18
36
188
878
6
244
6484
935
273
65
26
98
101
18
36
205
897
6
245
129
976
205
59
30
78
84
18
36
180
764
6
246
39583
896
163
59
15
18
18
9
36
202
769
6
247
5435
1011
149
82
20
78
84
18
36
175
820
6
248
256
1175
165
31
22
78
84
18
36
169
764
6
249
11270
810
151
58
21
18
18
9
36
198
755
6
250
6400
1043
224
52
19
100
101
18
36
191
806
6
251
80580
631
174
48
16
78
84
18
36
185
804
6
252
2246
1116
184
138
14
100
101
34
36
153
889
6
253
7998
826
216
109
30
98
100
18
36
204
939
6
254
13602
725
179
0
31
101
101
34
36
162
730
6
255
10272
858
153
64
36
97
101
34
36
181
764
6
256
806
837
134
59
14
98
101
34
36
182
832
6
257
23627
664
279
51
18
210
193
193
36
208
905
6
258
6321
919
120
30
21
78
84
18
36
173
761
6
259
13376
651
209
45
14
100
101
101
36
187
810
6
260
2198
708
190
53
17
99
101
34
36
206
782
6
261
5861
812
271
38
24
98
101
101
36
203
882
6
262
112
838
232
31
21
99
101
34
36
181
794
6
263
92
911
225
42
21
96
99
18
36
202
892
6
264
12163
621
233
84
23
100
101
34
36
181
760
6
265
6242
551
228
51
17
99
101
34
36
204
905
6
266
3123
754
167
57
29
78
84
18
36
169
776
102
6
267
14401
859
165
115
28
78
84
9
36
147
819
6
268
108
883
122
35
14
100
101
18
36
192
820
6
269
24355
770
245
75
32
101
101
18
36
170
900
6
270
59110
824
148
59
22
97
101
34
36
184
677
6
271
15128
909
203
111
21
78
84
18
36
206
940
6
272
10594
857
206
0
25
98
101
18
36
209
869
6
273
1076
822
239
46
14
97
101
34
36
185
838
6
274
106
1020
167
32
37
78
84
18
36
151
720
6
275
750
912
198
53
17
78
84
18
36
180
905
6
276
28118
804
157
36
24
78
84
84
36
186
840
6
277
69601
880
161
64
30
98
101
34
36
189
870
6
278
11390
998
121
33
17
78
84
84
36
162
715
6
279
127143
765
205
0
14
78
84
18
36
158
702
6
280
18895
837
157
96
24
101
101
34
36
179
818
6
281
2078
970
175
55
24
78
84
18
36
181
818
6
282
10239
725
292
70
19
191
193
193
36
211
927
6
283
220
613
310
36
20
221
193
193
36
175
856
6
284
8872
955
233
53
27
96
100
18
36
184
935
6
285
6943
659
149
0
15
78
84
9
36
177
917
6
286
6948
735
121
54
21
78
84
84
36
189
847
6
287
34584
526
224
37
25
98
101
101
36
165
780
6
288
193
766
151
41
23
78
84
84
36
173
817
6
289
91
498
225
32
35
100
101
34
36
183
828
6
290
77
518
246
50
23
101
101
18
36
197
930
6
291
92
755
214
45
20
100
101
18
36
164
676
6
292
6453
545
256
84
20
203
193
193
36
173
824
6
293
14881
825
163
96
26
101
101
34
36
183
792
6
294
9758
686
292
37
43
221
193
193
36
188
947
103
6
295
15373
1204
222
161
15
98
101
34
36
168
835
6
296
112
823
164
32
14
101
101
34
36
188
794
6
297
7493
852
104
47
20
97
101
34
36
170
752
6
298
7550
994
252
70
25
101
101
18
36
181
842
6
299
7610
649
137
40
22
97
101
101
36
192
760
6
300
13279
856
230
100
25
99
101
34
36
208
923
7
301
37625
7436
1143
107
24
242
217
44
49
302
1851
7
302
8660
7138
1048
116
34
257
217
87
49
270
1555
7
303
59869
7628
539
109
23
161
167
26
49
307
1629
7
304
61658
6687
1217
212
16
235
217
87
49
284
1728
7
305
14291
7253
1221
30
19
248
217
44
49
346
1608
7
306
197074
6216
1063
457
16
244
217
44
49
282
1564
7
307
30266
7655
564
57
17
41
44
14
49
301
1611
7
308
163207
7678
1257
1738
37
245
217
87
49
284
1634
7
309
339223
8880
659
233
20
163
167
26
49
316
1660
7
310
65822
6990
522
76
23
164
167
26
49
298
1561
7
311
22847
7795
565
183
26
160
167
14
49
310
1600
7
312
39415
7239
727
98
33
249
213
213
49
295
1426
7
313
105965
7037
853
109
42
160
167
26
49
267
1397
7
314
206350
6961
712
117
19
163
167
14
49
265
1452
7
315
19015
7457
514
89
39
163
167
26
49
243
1346
7
316
144
6844
643
98
27
41
44
26
49
311
1704
7
317
226782
5622
1560
0
28
718
388
388
49
339
1820
7
318
195472
5837
1108
98
18
242
217
216
49
304
1690
7
319
147592
6475
559
364
39
41
26
44
49
234
1505
7
320
1026592
8053
1177
659
16
162
167
26
49
308
1650
7
321
50845
6505
501
119
17
164
167
14
49
285
1579
7
322
372987
5453
1327
65
33
249
217
87
49
265
1647
104
7
323
610187
7415
429
215
18
160
167
167
49
315
1636
7
324
11421
6088
858
93
23
247
217
87
49
308
1850
7
325
92102
7894
374
82
19
41
44
44
49
261
1447
7
326
123776
6525
862
176
30
163
167
167
49
261
1571
7
327
7418
7650
458
86
35
162
167
44
49
295
1622
7
328
1626424
7854
1311
0
16
240
217
87
49
351
1858
7
329
53038
7273
446
199
16
161
167
14
49
281
1441
7
330
116952
7787
1109
137
43
161
167
14
49
298
1842
7
331
516375
8697
946
150
33
162
167
26
49
333
1843
7
332
20155
7609
1122
90
27
162
167
14
49
292
1629
7
333
3374
7515
802
115
17
164
167
167
49
324
1757
7
334
1995634
7488
1163
109
17
161
167
44
49
334
1719
7
335
8672
7659
1380
114
33
234
217
87
49
319
1878
7
336
155334
4861
920
0
20
239
217
217
49
331
1757
7
337
155838
10294
1146
191
46
161
167
44
49
318
1890
7
338
3786655
7664
866
358
50
41
44
44
49
250
1313
7
339
178600
6398
859
0
25
164
167
44
49
328
1751
7
340
107613
7415
823
114
29
159
167
167
49
314
1690
7
341
10404
9387
718
119
16
162
167
14
49
325
1825
7
342
33283
6684
903
0
20
241
217
44
49
335
1609
7
343
291984
9334
1083
164
26
161
167
14
49
297
1686
7
344
98622
6702
962
0
29
252
217
87
49
262
1416
7
345
105602
8114
1171
99
23
245
217
217
49
302
1776
7
346
813
5411
1085
98
17
475
388
388
49
310
1625
7
347
339101
5891
630
93
45
237
217
44
49
313
1629
7
348
74036
6846
1107
137
19
231
213
44
49
280
1512
7
349
36286
5037
1007
98
31
718
388
388
49
263
1666
7
350
59515
6310
591
66
17
220
217
44
49
311
1846
105
7
351
70566
8473
894
0
35
163
167
26
49
314
1550
7
352
98844
7995
907
145
27
161
167
26
49
300
1561
7
353
164
8558
1026
57
28
164
167
44
49
324
1671
7
354
48741
8050
1001
158
25
163
167
14
49
300
1818
7
355
207878
7845
719
138
25
160
167
14
49
285
1661
7
356
179343
5701
777
135
24
41
26
14
49
320
1792
7
357
9676
9514
1206
106
34
161
167
14
49
324
1605
7
358
238271
9167
1051
0
26
164
167
26
49
315
1747
7
359
603921
8333
680
100
24
41
44
14
49
344
1784
7
360
579407
7975
709
104
31
26
44
14
49
303
1859
7
361
8249
7926
596
79
19
41
44
44
49
336
1767
7
362
17185
8582
967
98
29
162
167
167
49
335
1676
7
363
38857
8322
410
88
27
162
167
26
49
298
1481
7
364
47939
8496
831
296
25
150
157
44
49
260
1483
7
365
121393
6474
369
81
25
158
167
14
49
233
1612
7
366
3495572
7026
949
4185
17
41
44
44
49
262
1377
7
367
99
7685
919
0
27
41
44
44
49
259
1518
7
368
3818
7332
720
69
17
41
44
44
49
302
1520
7
369
232893
8584
841
0
18
164
167
44
49
269
1511
7
370
111257
6943
1057
278
20
254
217
44
49
267
1646
7
371
983678
7684
1088
205
27
251
217
87
49
339
1671
7
372
14223
8953
1341
138
22
164
167
26
49
325
1675
7
373
176117
8713
851
101
29
164
167
14
49
320
1651
7
374
30908
6965
1137
100
20
164
167
14
49
313
1659
7
375
107
9305
1197
131
20
163
167
14
49
333
1822
7
376
126989
8216
824
206
39
159
167
167
49
333
1806
7
377
112
7630
1301
34
20
243
217
87
49
336
1880
7
378
141709
8047
953
280
25
41
44
26
49
306
1593
106
7
379
1466261
9865
1392
272
44
245
217
44
49
334
1573
7
380
65455
7551
976
165
19
41
44
26
49
337
1877
7
381
904619
7388
1053
135
24
162
167
26
49
253
1399
7
382
80223
5641
944
82
17
163
167
26
49
300
1548
7
383
66606
6665
1234
145
38
239
217
217
49
282
1804
7
384
5828
7490
1160
72
16
214
216
44
49
334
1889
7
385
24792
6481
881
258
34
230
217
44
49
269
1513
7
386
236278
6497
747
109
22
41
44
44
49
326
1843
7
387
674597
8261
898
0
17
160
167
14
49
311
1665
7
388
464156
9992
993
0
22
163
167
44
49
301
1661
7
389
31859
7450
731
1025
46
41
44
44
49
346
1869
7
390
1908
8613
1247
47
24
257
217
217
49
340
1867
7
391
24105
5743
796
53
16
234
214
87
49
289
1548
7
392
251257
7170
1264
0
60
257
217
217
49
291
1680
7
393
116
8214
912
32
47
159
167
44
49
336
1723
7
394
186743
6894
814
0
20
163
167
26
49
295
1520
7
395
231048
7602
783
101
22
164
167
167
49
276
1402
7
396
3033
7178
823
140
45
161
167
44
49
341
1583
7
397
49181
8336
596
157
19
163
167
14
49
307
1462
7
398
101159
5215
1269
95
31
508
388
388
49
355
1852
7
399
1252
7217
804
99
18
254
217
87
49
318
1875
7
400
173433
7661
890
0
22
156
162
26
49
271
1523
8
401
184
63410
4682
177
21
428
422
86
64
464
2801
8
402
213048
83693
3430
146
56
280
286
20
64
531
3364
8
403
3984321
94574
5860
713
30
336
315
103
64
505
3133
8
404
64005
86858
3388
109
37
282
286
20
64
519
3263
8
405
2285359
72899
7658
598
35
680
422
86
64
527
3433
8
406
552097
48331
5684
151
31
581
422
422
64
516
3354
107
8
407
1600946
65694
4236
98
26
327
315
103
64
415
2712
8
408
1674288
60523
6292
218
28
2532
710
710
64
511
3440
8
409
20928
72889
3888
141
30
279
286
20
64
493
3052
8
410
3998690
65103
4723
220
20
338
315
103
64
512
3284
8
411
2390176
56328
1677
175
33
57
60
36
64
475
3027
8
412
25737910
81514
4774
2431
27
276
286
38
64
556
3355
8
413
16352
66252
2561
169
39
57
103
20
64
410
2716
8
414
166
69859
2647
120
30
352
315
315
64
560
3007
8
415
65220
75212
2169
165
28
80
86
11
64
363
2779
8
416
4752
65189
4435
135
27
338
315
56
64
533
3404
8
417
2664
78754
4423
260
30
277
286
20
64
492
3091
8
418
85593826
73719
2988
1817
42
275
286
20
64
431
2700
8
419
57322154
47626
4142
673
25
57
60
60
64
538
3378
8
420
72679626
67795
3483
157
18
341
315
103
64
503
3290
8
421
84501
64354
2442
1445
23
316
315
60
64
544
3026
8
422
794791
71324
2299
195
48
308
310
305
64
502
3316
8
423
17065125
56110
4231
556
25
336
315
103
64
434
2804
8
424
2907
70571
2010
112
23
329
315
103
64
536
3416
8
425
3533
78340
3441
145
34
278
286
20
64
492
3065
8
426
157192
55231
5104
371
25
553
412
195
64
527
3410
8
427
1057913
41577
3257
1375
32
57
60
36
64
452
2902
8
428
13641715
48850
6347
3593
24
1868
710
710
64
489
3484
8
429
2,29E+08
67338
2655
1377
18
80
38
86
64
501
3037
8
430
6323861
65277
3921
2873
27
280
286
60
64
424
3114
8
431
373
64334
2616
110
25
80
86
20
64
443
2946
8
432
2718418
63016
2043
252
33
101
103
20
64
498
3135
8
433
26208
80922
3880
0
25
346
315
60
64
488
2989
8
434
8026120
77583
2652
1198
59
338
315
60
64
496
2990
108
8
435
318976
49424
5374
1026
68
2827
710
710
64
489
2942
8
436
3310295
58502
3135
0
23
313
315
60
64
529
3387
8
437
7221280
49791
1683
0
29
57
60
103
64
456
2940
8
438
16099
55177
4591
139
24
605
422
103
64
491
3002
8
439
4912218
68543
5276
248
29
591
420
103
64
440
2542
8
440
41407598
69099
2940
4671
32
80
37
20
64
483
3233
8
441
190190
58227
7566
133
43
620
422
103
64
497
3137
8
442
210
74709
5258
92
43
80
86
38
64
460
3083
8
443
398633
56266
2207
1331
37
677
422
86
64
509
3074
8
444
5048592
53903
1658
151
60
752
422
103
64
433
3227
8
445
267360
63223
6845
113
35
330
315
103
64
459
3375
8
446
67091
50529
3559
241
48
712
421
103
64
440
3086
8
447
41574264
79315
5946
3686
56
329
315
20
64
447
2646
8
448
3629001
64394
3912
464
36
335
315
103
64
495
3300
8
449
3260
71988
3256
96
20
305
315
60
64
477
3174
8
450
17250962
45890
2619
256
45
57
60
60
64
484
3076
8
451
1671446
70218
3682
139
24
341
315
20
64
429
2677
8
452
12573030
71575
7140
1480
24
325
315
36
64
487
3202
8
453
1703181
61410
8311
181
24
627
417
103
64
429
2656
8
454
680243
84198
4032
358
26
277
286
86
64
421
2688
8
455
279011
80254
3014
274
22
329
315
315
64
480
3058
8
456
79475
57176
5957
0
39
557
422
195
64
490
3360
8
457
57478
74224
2254
0
34
276
286
60
64
484
3065
8
458
2925907
78039
3381
331
37
281
286
20
64
517
3360
8
459
899521
77395
4642
283
42
349
315
315
64
510
2889
8
460
17023703
64497
4491
3249
18
279
286
20
64
482
3315
8
461
55856
57107
2867
128
23
280
286
86
64
386
2985
8
462
51421
82006
2634
315
38
344
315
20
64
483
2867
109
8
463
718476
56665
7602
120
69
2416
710
710
64
477
3193
8
464
95695
70877
3755
141
36
80
86
60
64
508
3088
8
465
6930956
74016
5534
607
21
332
315
36
64
438
3252
8
466
3319931
69863
3921
3710
27
306
315
20
64
403
2599
8
467
1682828
83481
7129
247
28
320
315
20
64
537
3337
8
468
304169
70782
4860
106
20
276
286
20
64
440
2918
8
469
21660283
73407
4545
1598
30
319
315
36
64
482
2848
8
470
1829704
61525
1884
0
42
54
60
20
64
449
2888
8
471
2738622
81100
4600
2348
23
310
315
36
64
453
2893
8
472
185
66265
4021
117
26
315
315
60
64
514
3250
8
473
175824
53155
2159
126
57
2124
710
710
64
417
2694
8
474
1189164
59828
1988
193
36
55
60
36
64
495
3024
8
475
28155915
76025
4400
1631
30
38
38
60
64
492
3057
8
476
45115479
78373
5016
237
30
276
286
86
64
474
3125
8
477
45861547
60603
5202
4762
21
644
422
195
64
421
2991
8
478
733571
73442
5160
273
26
324
315
36
64
537
3274
8
479
24986101
78287
3726
3046
46
337
315
103
64
443
2918
8
480
257941
60966
4416
961
22
636
420
195
64
438
2608
8
481
40075
70131
3138
525
30
335
315
20
64
470
3260
8
482
14026
52474
10060
83
48
614
422
103
64
530
3396
8
483
6741728
78012
2991
4940
24
279
286
11
64
404
2987
8
484
2923
62404
5723
117
18
680
422
195
64
537
3091
8
485
199723
61887
4355
188
26
541
418
195
64
481
3017
8
486
10321458
86649
4195
2268
24
310
315
103
64
443
2904
8
487
462662
53621
7074
204
22
704
422
86
64
451
2847
8
488
4673782
84688
4999
107
28
276
286
20
64
530
3161
8
489
4761911
69168
2677
283
33
338
315
103
64
387
3027
8
490
190643
60550
6425
120
26
332
315
20
64
466
2975
110
8
491
77118
71580
3027
261
33
281
286
20
64
486
3118
8
492
1801
79252
4913
96
42
323
315
56
64
467
2984
8
493
2392569
59858
2094
146
48
352
315
315
64
470
2863
8
494
242379
49636
2198
160
28
325
305
60
64
531
3421
8
495
38876
49045
4697
127
18
2590
710
710
64
515
3426
8
496
1588503
69409
6531
137
54
278
286
286
64
489
3130
8
497
310424
64909
2592
85
40
38
38
20
64
438
2881
8
498
7966319
54310
5309
1589
47
337
315
60
64
539
3422
8
499
177
49311
4228
54
21
345
315
20
64
538
3423
8
500
5187330
73697
2531
271
27
281
286
60
64
454
3199
9
501
634078
16114
3262
27
472
482
131
81
700
5423
9
502
693694
13271
2846
59
110
88
28
81
757
5239
9
503
490730
33782
499
24
7433
1207
1207
81
736
5165
9
504
765148
7393
177
49
493
482
46
81
741
4583
9
505
779924
27222
550
77
489
482
482
81
677
5446
9
506
612019
10483
446
26
2892
756
169
81
609
5021
9
507
699071
12136
2022
47
115
126
46
81
589
5113
9
508
634394
32217
189
38
2295
755
169
81
596
4087
9
509
667028
16641
216
60
491
482
28
81
736
5462
9
510
795125
20853
1271
23
485
482
28
81
687
5312
9
511
750685
15731
0
46
164
169
131
81
645
5045
9
512
600645
18972
0
44
2628
756
219
81
611
5190
9
513
651339
6157
214
27
481
482
28
81
727
5152
9
514
624858
11733
1578
64
744
555
560
81
673
4756
9
515
665200
20636
1912
23
498
482
46
81
781
5681
9
516
686303
20430
1831
40
463
460
46
81
628
5563
9
517
605226
12755
11118
29
2638
752
219
81
662
5297
9
518
592511
16100
154
20
785
560
219
81
621
4439
111
9
519
676824
16897
2854
32
487
482
88
81
696
5606
9
520
699285
7645
0
53
506
482
46
81
719
5466
9
521
675375
7238
328
30
839
560
560
81
608
5111
9
522
618844
4820
221
29
482
482
46
81
664
4984
9
523
596847
19400
259
46
2246
756
169
81
720
4600
9
524
698759
26187
517
28
481
482
28
81
641
4548
9
525
709498
17899
209
40
479
482
125
81
696
5648
9
526
584179
17697
1727
26
761
560
46
81
701
5212
9
527
665679
21172
8161
33
496
482
46
81
786
5564
9
528
735304
20998
3064
39
777
555
126
81
742
5567
9
529
618869
6760
176
55
3049
756
219
81
674
4849
9
530
550524
19972
258
26
85
88
16
81
704
4762
9
531
487927
29192
4022
25
2473
756
756
81
791
5062
9
532
650453
20041
3370
60
482
482
28
81
779
5562
9
533
689632
33597
514
52
848
560
46
81
755
5683
9
534
685412
32501
1752
49
647
560
219
81
790
5760
9
535
605305
44837
0
21
484
482
28
81
688
5255
9
536
655552
16622
150
21
734
560
217
81
662
5277
9
537
583065
15182
385
32
120
88
117
81
752
5407
9
538
672688
15808
212
29
616
505
205
81
734
5739
9
539
737645
21791
0
49
481
482
126
81
717
5721
9
540
548723
16183
250
22
130
219
126
81
784
5521
9
541
707760
9950
240
38
488
482
28
81
760
4949
9
542
688172
9322
676
34
163
126
28
81
714
5176
9
543
723875
21894
4250
24
501
482
28
81
730
5200
9
544
577469
26698
3382
47
2257
750
169
81
687
5101
9
545
570584
9326
329
44
677
560
89
81
732
4998
9
546
639104
11193
271
44
164
169
46
81
643
4882
112
9
547
499090
38443
202
60
2998
756
390
81
719
5430
9
548
564002
10975
2679
39
788
560
128
81
565
4738
9
549
580176
18142
1782
54
7677
1207
1207
81
665
4808
9
550
714768
27268
256
35
486
482
46
81
660
5579
9
551
801020
28603
216
31
514
482
46
81
692
5232
9
552
524229
19263
150
20
719
560
219
81
660
4991
9
553
658674
32574
6264
29
872
560
46
81
747
5707
9
554
626195
7377
340
35
2905
748
219
81
777
5066
9
555
636717
11003
223
24
824
560
89
81
715
5603
9
556
746298
29724
3514
21
163
169
28
81
586
5696
9
557
685487
24689
3965
27
501
482
131
81
715
5165
9
558
621366
6825
561
52
812
560
131
81
772
4733
9
559
727577
21315
4860
37
163
169
46
81
668
5128
9
560
422672
8846
203
63
120
126
46
81
635
4476
9
561
674690
19014
4292
20
481
482
28
81
641
4889
9
562
626280
23643
9251
25
779
560
46
81
727
5234
9
563
755626
31873
283
68
848
560
125
81
742
5654
9
564
818878
11961
211
37
493
482
131
81
694
5496
9
565
706152
10656
208
24
513
482
28
81
748
5299
9
566
829776
30615
199
23
491
482
46
81
609
4366
9
567
612286
25547
2542
24
3036
752
219
81
788
5313
9
568
591682
17171
151
32
752
560
89
81
554
4340
9
569
651595
21251
3653
49
815
560
219
81
760
5349
9
570
786638
31618
336
37
500
482
46
81
676
5229
9
571
601724
13108
1446
34
128
219
126
81
672
4900
9
572
680504
8574
6030
28
483
482
28
81
711
5229
9
573
735570
16923
5097
66
494
482
28
81
704
5133
9
574
702176
6061
602
62
629
560
126
81
622
4436
113
9
575
483409
44680
1939
62
15495
1207
1207
81
696
5017
9
576
733265
15716
2313
26
501
482
28
81
704
5304
9
577
659309
11289
155
23
120
88
16
81
685
5030
9
578
695969
17381
151
31
163
169
28
81
759
5400
9
579
540464
29869
1473
50
3234
756
169
81
707
5769
9
580
622010
35805
869
41
2692
756
219
81
684
4932
9
581
600916
19567
310
27
646
535
122
81
780
5626
9
582
629366
19227
285
40
824
560
89
81
743
5627
9
583
709170
14984
636
58
477
482
169
81
602
4461
9
584
791246
17319
259
21
166
164
88
81
731
5286
9
585
623746
20949
23743
33
818
560
89
81
574
4297
9
586
467045
26269
0
46
10778
1207
1207
81
671
5216
9
587
591843
10020
3206
38
827
560
46
81
619
4692
9
588
596898
5113
388
86
162
169
28
81
634
5107
9
589
710943
38370
1874
69
818
560
46
81
723
5564
9
590
821733
19756
439
33
501
482
16
81
696
5082
9
591
784555
25642
6615
65
785
560
46
81
771
5365
9
592
556466
26613
5301
31
4564
1207
1207
81
674
5193
9
593
813155
17743
567
41
504
482
88
81
705
5440
9
594
651684
8495
182
23
490
482
131
81
574
5677
9
595
612686
10159
4052
33
128
219
46
81
767
5334
9
596
525671
12932
5776
45
1502
752
756
81
672
5188
9
597
592516
16867
5702
55
2713
756
390
81
757
5417
9
598
656924
25182
397
22
85
88
169
81
717
5380
9
599
714039
27132
0
51
800
560
219
81
733
5567
9
600
666331
13521
5727
21
493
482
28
81
705
5071
10
601
8295667
105962
2620
32
281
288
202
100
902
7751
10
602
8095740
72228
7149
24
786
742
40
100
964
8742
114
10
603
7276447
48459
481
27
1025
787
256
100
1079
8960
10
604
6291114
30844
264
27
194
201
40
100
1018
8209
10
605
7882334
53133
8733
41
2962
942
105
100
923
7401
10
606
5280689
36024
782
56
196
183
62
100
954
7832
10
607
7971311
42369
5768
33
147
202
13
100
781
6444
10
608
5888910
145748
1772
24
19538
1267
288
100
1074
8989
10
609
8053835
40384
344
27
869
787
62
100
976
8218
10
610
8386059
80036
2268
40
759
742
196
100
1031
8586
10
611
7900180
52830
1063
22
980
787
40
100
987
7930
10
612
8724260
101888
30040
26
282
288
202
100
1029
8136
10
613
6683522
184171
179
59
2402
942
245
100
1067
9059
10
614
7590715
86792
0
26
746
742
22
100
1086
8858
10
615
7755376
96215
3923
24
1602
907
88
100
1105
8545
10
616
7586236
61076
4294
98
237
202
40
100
1019
8200
10
617
7601532
139956
9081
24
2292
922
245
100
955
8609
10
618
6795147
45239
791
24
196
202
88
100
959
7757
10
619
6930938
76804
342
24
194
202
62
100
969
7959
10
620
7916769
114020
3200
27
777
742
22
100
960
7503
10
621
7042752
132248
3684
26
2851
942
245
100
1072
8955
10
622
7123458
85864
1162
31
234
245
22
100
1050
8522
10
623
6756123
104315
31084
61
1555
942
197
100
831
7532
10
624
5447701
140239
0
30
14066
1267
424
100
1009
8238
10
625
6266783
30066
1606
28
223
192
62
100
1037
8168
10
626
7128046
100721
7486
27
1022
787
62
100
1016
8864
10
627
6166307
16025
306
45
175
185
40
100
1042
8700
10
628
4637916
46656
3330
28
196
192
40
100
914
7842
10
629
6927440
20245
198
56
2634
942
105
100
1041
8455
10
630
7277263
67884
374
40
822
742
288
100
905
7304
115
10
631
7103719
39090
2589
23
191
183
62
100
968
8178
10
632
8862822
59155
0
68
991
787
278
100
919
7977
10
633
7049808
180045
8647
41
971
787
40
100
850
6743
10
634
5014811
76334
514
31
54714
1935
1935
100
928
7221
10
635
5200898
163959
0
25
3339
942
942
100
1019
8853
10
636
5988726
300459
25830
29
17422
1267
712
100
1006
8766
10
637
5168939
53991
8318
53
241
202
62
100
869
8616
10
638
6618571
68117
5136
94
804
787
62
100
1039
8356
10
639
7432534
146327
18637
36
941
787
62
100
1065
9017
10
640
5826581
48492
0
48
151
183
60
100
1026
8568
10
641
7092370
75466
5829
27
1058
787
62
100
1037
7877
10
642
6047173
118154
162
23
2148
937
424
100
865
7265
10
643
6898025
85223
1128
23
228
183
62
100
995
8601
10
644
6746211
73411
1604
24
979
787
105
100
1059
8298
10
645
7467576
58149
594
39
931
787
22
100
895
8692
10
646
7929305
165314
25088
27
1097
787
62
100
937
7892
10
647
7569313
129866
6834
39
891
787
105
100
938
8414
10
648
5108059
133461
3678
54
2103
942
424
100
970
8059
10
649
7940911
135124
128
29
772
742
202
100
891
7524
10
650
6699597
94574
3446
24
217
202
38
100
980
7534
10
651
6490687
104150
5887
26
241
183
263
100
1064
8578
10
652
8054834
101184
8681
22
1082
787
317
100
1005
8353
10
653
6206502
226831
5559
45
17781
1265
288
100
1042
9005
10
654
6407440
104833
24348
40
1107
787
245
100
906
7204
10
655
7774868
171752
662
68
2383
942
105
100
812
6817
10
656
7413740
128338
0
42
1430
942
197
100
870
7119
10
657
8234369
179947
298
24
1018
787
263
100
995
8089
10
658
6017915
145796
27815
73
12550
1267
712
100
1108
8232
116
10
659
7666488
87774
6301
30
281
288
62
100
845
7787
10
660
7937863
60266
0
32
279
288
22
100
959
7770
10
661
6929971
73349
20386
50
180
183
62
100
1005
8048
10
662
6220657
141045
224
26
1881
942
263
100
1030
8966
10
663
5243960
321730
290
23
74988
1935
1935
100
875
7661
10
664
7591010
44219
1525
23
1026
754
22
100
962
8845
10
665
5544614
114082
1629
39
2362
942
62
100
1095
8671
10
666
7584382
59808
277
23
752
742
22
100
1003
8240
10
667
7796202
160654
17839
51
2339
942
88
100
1092
8141
10
668
6412034
87072
251
45
1058
787
787
100
1055
8848
10
669
7576190
79069
546
43
887
787
40
100
977
9047
10
670
7558860
83574
2424
30
918
787
38
100
1027
8848
10
671
7333014
61701
10848
25
1025
787
183
100
885
7704
10
672
6229966
61812
41978
58
2368
937
263
100
930
7907
10
673
7802588
37325
223
39
790
742
22
100
918
6912
10
674
7084842
97782
265
39
281
202
22
100
1026
8649
10
675
7671289
104546
32164
23
887
787
62
100
1022
8736
10
676
7150911
138425
14905
61
3351
942
105
100
1046
8554
10
677
6522885
184110
8281
41
1076
787
245
100
965
8488
10
678
7001744
131357
4441
53
985
787
38
100
1091
8898
10
679
7399555
41946
272
47
883
765
62
100
869
8266
10
680
6061185
32916
329
58
281
424
62
100
952
7902
10
681
7623910
192263
248
55
992
787
62
100
1000
7997
10
682
6914528
65828
258
24
202
202
22
100
1037
8434
10
683
5681549
47275
9955
48
279
202
62
100
902
7908
10
684
7466746
58223
173
34
1037
787
263
100
788
6347
10
685
7466517
23055
240
80
772
742
22
100
1007
8045
10
686
8267823
98020
543
69
325
317
245
100
850
7663
117
10
687
7030368
138824
322
26
335
317
62
100
1032
8294
10
688
5106946
78021
5893
33
1944
942
263
100
1042
8910
10
689
6565722
185882
2580
38
754
424
245
100
1019
8278
10
690
5516721
159098
2736
57
19954
1267
317
100
1100
7927
10
691
7434692
90511
13941
27
882
787
288
100
1077
8053
10
692
7988410
185272
36344
37
2259
942
62
100
992
7358
10
693
6670025
77745
2144
44
864
787
245
100
1028
7771
10
694
6790219
66989
5346
60
907
787
105
100
1021
6974
10
695
5161104
197445
267
33
147174
1935
1935
100
1053
9008
10
696
6844785
130033
4380
50
196
202
88
100
1018
8153
10
697
8044990
87405
0
68
749
742
40
100
1048
8250
10
698
6886304
93591
0
44
840
787
62
100
1062
8619
10
699
7695742
48007
3720
46
763
742
22
100
899
8697
10
700
8192343
124151
341
34
1025
787
183
100
994
7861
11
701
249868
7859
34
3621
1241
128
121
1477
13496
11
702
881064
47826
42
87
90
133
121
1237
11768
11
703
210510
22637
43
10554
1509
436
121
1423
13276
11
704
120976
530
31
1221
1127
128
121
1189
10116
11
705
534017
0
38
2839
1241
30
121
1428
12607
11
706
287122
642
30
1370
1127
551
121
1342
12369
11
707
279340
6615
42
1233
1070
128
121
1339
12596
11
708
467227
9901
77
1248
1127
30
121
1402
12237
11
709
553966
407
57
2367
1241
128
121
1435
13161
11
710
517437
1612
36
1575632
2958
2958
121
1312
11926
11
711
163809
47806
63
1317
1127
48
121
1454
13357
11
712
318373
3758
29
2749
1230
221
121
1385
13560
11
713
373382
7139
35
482
484
484
121
1259
11947
11
714
205193
19060
39
1390
1127
128
121
1471
10223
118
11
715
633210
25660
39
2650
1241
133
121
1249
11532
11
716
301538
3943
37
1338
1127
90
121
1469
13431
11
717
1042746
5952
45
460717
2958
2958
121
1334
12710
11
718
889141
417
67
87890
2003
562
121
1506
13869
11
719
407073
16092
24
389
393
48
121
1330
11476
11
720
365307
560
76
370
383
90
121
1477
13513
11
721
167557
2875
52
295
298
436
121
1274
11421
11
722
549582
0
24
53767
2011
562
121
1351
13190
11
723
749326
78005
27
152512
2011
758
121
1384
12459
11
724
190649
423
31
321
393
128
121
1310
11720
11
725
1244927
15312
42
1392
1127
133
121
1059
9560
11
726
337036
273
55
1180
1127
551
121
1253
12494
11
727
860595
70363
50
2790
1241
48
121
1315
12584
11
728
344009
0
33
1461
1127
30
121
1207
10838
11
729
149786
408
36
3089
1241
441
121
1483
13470
11
730
643263
12229
28
103870
2011
1209
121
1431
13627
11
731
94291
327
45
477
484
59
121
1179
10891
11
732
214009
5844
28
88265
1982
484
121
1252
11001
11
733
153980
437
43
3081
1241
128
121
1268
11709
11
734
578273
5885
32
1359
1127
128
121
1453
13302
11
735
422644
6762
56
487
338
48
121
1397
13321
11
736
266003
329
55
505
484
166
121
1432
12656
11
737
413878
13018
34
16408
1509
758
121
1295
13392
11
738
142968
0
27
487
484
30
121
1278
11840
11
739
379368
32760
31
456
441
171
121
1282
11024
11
740
488606
460
32
1379
1127
436
121
1152
11414
11
741
201983
440
30
1401
1127
56
121
1214
12373
11
742
926413
35041
51
17206
1509
440
121
1166
12771
119
11
743
204973
31654
40
386
343
90
121
1342
11728
11
744
175955
33892
33
9002
1499
758
121
1324
12781
11
745
404150
1642
46
499
493
128
121
1227
11136
11
746
641909
421
61
1254
1127
48
121
1432
13034
11
747
207966
1757
52
344
393
30
121
1388
12568
11
748
273983
22667
31
356
388
30
121
1079
13299
11
749
310147
18470
29
1820
1241
123
121
1325
13387
11
750
348350
6486
54
499
391
18
121
1433
12791
11
751
534820
31582
57
2511
1241
221
121
1274
11580
11
752
610279
6971
29
10637
1509
171
121
1320
12790
11
753
150478
12822
33
1156
1108
90
121
1281
11239
11
754
344873
691
45
375
347
119
121
1403
12617
11
755
320986
5483
54
1251
1127
90
121
1406
12446
11
756
484620
12849
35
14088
1504
392
121
1425
12902
11
757
417585
14719
39
494
484
18
121
1499
13027
11
758
154590
235
29
3029
1241
416
121
1241
11420
11
759
561821
11161
41
11970
1494
221
121
1412
12468
11
760
145643
14956
40
430
393
171
121
1243
12756
11
761
172603
553
27
1236
1127
18
121
1373
12336
11
762
386247
30896
51
8134
1489
133
121
1501
13402
11
763
850001
22494
45
10813
1509
441
121
1372
12956
11
764
594176
12556
31
15486
1509
171
121
1374
12207
11
765
345453
236
27
1278
1127
171
121
1258
11471
11
766
556638
7936
53
499
508
18
121
1397
12296
11
767
287152
383
24
6142
1509
171
121
1350
12373
11
768
1249866
3368
68
135475
2011
562
121
1251
11357
11
769
276745
183
24
2683
1241
221
121
1228
12352
11
770
784667
355
38
21610
1509
432
121
1434
12442
120
11
771
360974
5509
29
3684
1241
128
121
1447
13369
11
772
759071
43459
25
83823
2010
484
121
1279
11757
11
773
652811
4830
29
1297
1127
128
121
1198
12472
11
774
325548
5034
33
5892
1509
441
121
1420
13776
11
775
258240
7407
39
2567
1241
294
121
1411
10801
11
776
450729
0
39
340
498
30
121
1116
11582
11
777
577011
11907
26
489
483
48
121
1402
12813
11
778
884079
1817
38
178684
2011
562
121
1477
13395
11
779
619515
436
41
408
393
90
121
1326
12303
11
780
473038
21992
42
18641
1509
361
121
1430
12995
11
781
188907
22677
25
3221
1241
133
121
1334
12563
11
782
117643
438
27
365
393
128
121
1137
10628
11
783
361851
0
34
1614
1197
48
121
1466
13060
11
784
1146642
81133
28
3152
1241
128
121
1389
12873
11
785
245174
24673
45
497
484
90
121
1199
11476
11
786
694303
24474
30
18732
1509
128
121
1440
12835
11
787
1083134
10141
25
1408
1127
128
121
1417
12935
11
788
348536
503
28
6873
1484
471
121
1497
13616
11
789
328236
30983
28
366
371
30
121
1120
11409
11
790
947359
37219
46
18209
1509
128
121
1361
12821
11
791
291172
5436
43
2400
1241
562
121
1343
13256
11
792
181607
1317
71
2023
1241
128
121
1438
12930
11
793
893817
387
24
3310
1241
48
121
1332
12253
11
794
1001653
14330
34
2216
1241
48
121
1394
13054
11
795
981727
4978
59
155482
2011
758
121
1409
13640
11
796
146952
2114
42
369
316
133
121
1360
11140
11
797
479596
8428
51
1303
1127
128
121
1399
11408
11
798
142476
441
36
19942
1509
171
121
1237
11072
121
11
799
272543
295
42
146785
2011
562
121
1414
13756
11
800
979962
3479
36
17319
1509
392
121
1320
12408
12
801
492285
0
29
1936
1612
825
144
1757
17100
12
802
3555648
1219
39
929
685
247
144
1809
18200
12
803
1025130
54261
45
103732
2287
1268
144
1490
15585
12
804
1074291
0
34
3857
1677
64
144
1898
19346
12
805
6632712
9748
57
171265
2317
846
144
1876
16475
12
806
1342361
653
48
3462
1677
1677
144
1838
18350
12
807
3957441
252810
41
629280
3020
1269
144
1858
19766
12
808
2156569
20085
26
2405
1658
290
144
1664
17744
12
809
1004887
535
54
4031
1677
204
144
1865
18658
12
810
4166117
22537
49
3634
1677
167
144
1899
19020
12
811
1132728
4195
32
15278
1892
214
144
1569
15810
12
812
271054
32910
46
774
617
142
144
1711
17748
12
813
4816941
70524
91
122065
2317
846
144
1694
17936
12
814
3149109
44503
47
13622
1892
63
144
1908
18707
12
815
180063
863
26
3336
1639
204
144
1554
16348
12
816
7508847
101763
27
15112
1892
185
144
1872
18342
12
817
1517530
18178
32
3691
1677
64
144
1808
17076
12
818
3799804
290667
66
1378
204
90
144
1730
17645
12
819
926252
30587
32
1798
1612
42
144
1905
18838
12
820
784520
14431
31
2699
1677
64
144
1842
18890
12
821
4270164
778
59
32149
2317
265
144
1744
17819
12
822
1841800
4272
34
1346253
3051
789
144
1877
17945
12
823
1131619
31223
73
20432
1892
185
144
1841
19000
12
824
1342865
15493
39
18858
1815
426
144
1874
19638
12
825
1403968
380
27
12470
1892
185
144
1624
16301
12
826
6038750
25068
45
1378862
3052
1937
144
1851
19086
122
12
827
1825527
55987
45
123045
2307
247
144
1731
19457
12
828
2218383
12414
87
978
947
42
144
1885
18752
12
829
5298019
4061
32
8828
1892
426
144
1780
18852
12
830
1516810
59067
28
14683
1892
107
144
1843
19836
12
831
1156030
5658
31
113266
2302
714
144
1692
19208
12
832
1445429
15203
77
885
987
40
144
1802
17491
12
833
1496321
606
82
3907
1677
728
144
1749
19354
12
834
2216847
15673
39
2598
1677
40
144
1466
13890
12
835
1317870
57797
48
3309
1677
828
144
1770
17117
12
836
4875803
40619
27
1626518
3040
1249
144
1723
18691
12
837
3338323
35957
32
12218
1892
90
144
1602
15366
12
838
5199704
793
82
17965
1892
944
144
1833
18340
12
839
2698061
33673
35
1750
1612
64
144
1739
19327
12
840
2257872
40107
29
635
685
265
144
1815
18437
12
841
1536516
39167
58
1378
704
64
144
1736
17648
12
842
4210298
4055
29
10417
1892
107
144
1760
17992
12
843
1951090
48546
31
149740
2317
746
144
1796
19905
12
844
1035824
116805
35
2066
1620
185
144
1791
18495
12
845
365454
5392
28
875
846
426
144
1831
18613
12
846
3702430
28007
30
12210
1892
265
144
1752
18414
12
847
1656422
11188
44
18204
1892
199
144
1651
16951
12
848
1708809
411
41
3555
1677
42
144
1539
18277
12
849
799786
36322
27
18991
1892
626
144
1818
18547
12
850
774334
0
44
2895
1677
40
144
1585
16968
12
851
474776
5604
97
18963
1892
185
144
1742
16844
12
852
894241
5786
32
3242
1677
64
144
1824
18170
12
853
1038631
53810
33
3215
1677
142
144
1663
18351
12
854
662783
668
44
3721
1677
24
144
1909
18088
123
12
855
2751649
660
38
14742
1892
64
144
1909
19659
12
856
385041
4975
30
643
706
64
144
1928
19030
12
857
3843937
20053
30
171826
2317
319
144
1773
19994
12
858
1777423
7616
44
975
987
247
144
1750
18183
12
859
624671
5417
61
978
670
192
144
1644
19181
12
860
1406581
29713
36
703
987
185
144
1605
16260
12
861
1998124
694
66
980
728
204
144
1901
18173
12
862
2066015
62598
33
3741
1677
64
144
1890
18316
12
863
1874565
26733
71
52671
2292
1245
144
1704
17570
12
864
5780613
29664
41
134100
2307
290
144
1697
17352
12
865
2866327
70178
29
3380
1677
64
144
1807
19341
12
866
2062983
644
47
3553
1677
64
144
1864
18566
12
867
3636810
123849
52
160363
2317
319
144
1836
16461
12
868
415335
9857
26
968
987
24
144
1646
18070
12
869
1700035
77624
43
539
1390
24
144
1708
16979
12
870
7946709
18615
26
3805404
4348
4348
144
1799
18618
12
871
646331
618
41
721
673
90
144
1900
15749
12
872
1468651
16862
59
173551
2317
319
144
1661
16976
12
873
4676434
65043
69
2023
1612
90
144
1920
16225
12
874
2452089
26519
26
115840
2317
1269
144
1905
19840
12
875
1021544
2415
48
659
1390
24
144
1705
17786
12
876
1886781
49228
62
76276
2317
319
144
1663
19795
12
877
629536
6297
33
775
909
200
144
1773
17820
12
878
2558296
532
43
3077
1639
728
144
1932
18039
12
879
4673267
27467
46
149140
2317
247
144
1712
17357
12
880
1435897
7990
78
726
719
24
144
1718
19024
12
881
2463913
30169
69
715
728
204
144
1733
19180
12
882
728713
0
33
968
852
204
144
1891
18641
124
12
883
1389959
54045
62
16744
1892
426
144
1736
19009
12
884
897561
158902
38
723
1240
64
144
1858
16958
12
885
3668347
61676
45
175495
2317
1269
144
1693
17034
12
886
1036360
90139
37
3434
1677
187
144
1819
19480
12
887
1100576
794
61
726
987
64
144
1740
17986
12
888
1964204
2995
87
18128
1892
64
144
1805
18476
12
889
847677
0
27
1378
902
42
144
1597
17016
12
890
2173212
118716
32
3863
1677
24
144
1714
17212
12
891
502178
1003
79
1148
1390
42
144
1564
17353
12
892
1472900
11655
72
126082
2317
256
144
1867
17538
12
893
1759751
316
90
978
770
64
144
1787
18519
12
894
3185428
2299
53
726
680
24
144
1822
18961
12
895
1779018
13451
41
3422
1677
64
144
1838
18068
12
896
2025150
6476
54
3782
1677
883
144
1810
17107
12
897
1878446
0
114
980
1380
90
144
1797
18528
12
898
3026792
45282
42
13434
1892
247
144
1690
18505
12
899
2532133
11206
47
1837
1612
64
144
1837
18345
12
900
1188674
0
32
2146
1677
64
144
1801
18495
13
901
14964120
52148
48
944006
3430
553
169
2404
27651
13
902
10353158
17348
47
21818
2440
92
169
2166
24889
13
903
18184420
46148
30
1895
1638
135
169
2436
25773
13
904
2266121
609
45
4302
2282
173
169
2450
26919
13
905
13233769
26130
44
3822
2282
50
169
2299
25575
13
906
8878630
7263
57
36785
2796
349
169
2194
24758
13
907
5836741
6980
41
14762
2421
92
169
2118
26249
13
908
20422786
8669
31
1712388
3430
1190
169
2212
25334
13
909
10550236
25290
47
3413
2282
384
169
2147
25070
13
910
11057188
36916
32
171325
2796
1200
169
2073
23574
125
13
911
1559575
35726
30
2721
376
553
169
2159
22397
13
912
5829251
58228
67
3289
2282
32
169
2452
25294
13
913
19351265
554
35
55862
2796
173
169
2429
27076
13
914
5473359
9781
72
9697
2440
564
169
2340
23928
13
915
2235397
33195
34
2985
2282
352
169
2431
25959
13
916
10184570
37848
48
101144
2796
173
169
2466
26147
13
917
20583791
11040
59
3263
2282
510
169
2162
25835
13
918
3349800
633
55
19217
2383
308
169
2471
26211
13
919
18168657
32573
66
18719
2440
553
169
2367
25355
13
920
29210897
3905
41
3470
2282
510
169
2184
24362
13
921
2928582
10390
51
160532
2763
490
169
2329
25502
13
922
14803561
32035
49
18813
2440
135
169
2181
24352
13
923
3592225
746
32
867
1110
135
169
2269
26406
13
924
52674483
6982
47
1300
1129
439
169
2472
24867
13
925
7865855
5567
29
2314
2733
130
169
2253
25371
13
926
39920398
12112
39
14987
2440
490
169
2348
26063
13
927
6316816
48908
43
13056
2440
130
169
2162
21871
13
928
16732232
144175
63
1331311
3430
443
169
2412
27099
13
929
3054734
718
46
15529
2440
1706
169
2228
25300
13
930
4468395
111573
54
3464
2282
50
169
2436
27015
13
931
16089208
0
68
5675
2364
135
169
2332
24684
13
932
4702006
746
44
11493
2440
223
169
2436
26824
13
933
1338063
4747
33
2722
1173
62
169
2257
22216
13
934
5298391
556
56
19819
2421
349
169
2184
25431
13
935
4845919
55999
70
2719
341
384
169
2184
23849
13
936
20531012
24619
61
3332
2282
1153
169
2310
27499
13
937
5884510
50944
34
1526022
3430
1153
169
2360
26946
13
938
2307533
0
42
1383
1129
32
169
2279
22831
126
13
939
7037193
6493
95
12540
2440
395
169
2306
23900
13
940
9295974
60547
69
11823
2440
50
169
1915
24376
13
941
2923059
38677
80
1333
1257
114
169
2306
24486
13
942
2941914
57267
37
2034
1854
32
169
2331
26207
13
943
4489137
0
40
12838605
4438
1129
169
2487
27555
13
944
5608181
470
54
1649
1579
395
169
2169
25893
13
945
28965959
8968
31
2724
2447
32
169
2339
26990
13
946
2123956
4860
54
72503
2796
438
169
2444
24524
13
947
6183594
0
33
3739
2282
32
169
2317
26817
13
948
5722384
35835
35
909
1212
92
169
1812
22636
13
949
10008005
15616
28
3327
2282
486
169
2421
25936
13
950
5497867
56001
29
143896
2796
892
169
2362
25630
13
951
3357131
981
34
2626
2282
395
169
2208
24075
13
952
4292477
12981
33
1889
1898
32
169
2465
24893
13
953
2365127
429
78
4303
2282
50
169
2246
24239
13
954
28942220
53153
46
518278
3415
490
169
2411
28131
13
955
7369773
501325
57
1415636
3430
1200
169
2401
26373
13
956
2370831
128878
52
1676
320
92
169
2201
25793
13
957
11718874
6966
44
1515988
3430
909
169
2460
27861
13
958
11983590
446
58
12385
2440
93
169
2408
25669
13
959
15125318
55878
35
150061
2796
1045
169
2319
25532
13
960
10556369
10411
62
156931
2796
760
169
2122
22782
13
961
6750301
115535
40
4360
2282
92
169
2156
24701
13
962
13512590
31206
29
2719
1485
510
169
2339
25594
13
963
21413644
0
62
124805
2796
135
169
2226
27895
13
964
63129231
365372
52
1737953
3430
490
169
2526
28032
13
965
10866255
24176
61
2599
2282
1129
169
2490
27473
13
966
6152884
1181
55
25278
2774
394
169
2384
22005
127
13
967
4963384
7816
43
2933
2282
62
169
2237
23708
13
968
25309788
23237
31
550363
3430
490
169
2317
27596
13
969
8682531
587881
35
140386
2796
490
169
2387
25177
13
970
6120769
402
40
3407
2282
438
169
2409
27276
13
971
10783626
15988
56
2720
1868
510
169
2220
24276
13
972
38580717
66651
38
10260735
4462
1243
169
2374
27982
13
973
4128633
23764
34
4123
2282
32
169
1981
22614
13
974
5995517
16545
31
62933
2796
130
169
1931
24808
13
975
15518339
118734
47
106660
2796
332
169
2391
25555
13
976
6377021
5241
64
467757
3405
760
169
2230
27890
13
977
19275788
720
55
2870
2282
130
169
2441
26998
13
978
22988390
35638
31
13485
2440
223
169
2210
25426
13
979
6908982
51821
47
3096
2282
32
169
2435
26371
13
980
4289768
10156
53
1529
1777
349
169
2417
25426
13
981
13256165
118862
71
77833
2796
394
169
2247
27838
13
982
11018826
29454
28
6439
2440
443
169
2503
26581
13
983
8085700
20431
35
3014
2282
486
169
2300
25349
13
984
13932388
47107
48
3504
2282
92
169
2132
27118
13
985
3788804
15568
47
13916
2440
50
169
2027
21675
13
986
5324052
0
82
16720
2421
50
169
2389
25329
13
987
15637549
9020
28
2568
2166
92
169
2370
26114
13
988
33880002
16277
63
6779096
4460
2013
169
2324
26970
13
989
57820969
160712
42
122446
2796
223
169
2215
27200
13
990
14005324
30513
91
168655
2796
443
169
2343
27897
13
991
17574569
38279
50
16656
2440
92
169
1977
22268
13
992
1997826
0
40
3856
2282
32
169
2248
27389
13
993
15490298
824
58
176699
2796
173
169
2339
26102
13
994
6588421
769
31
1857
1898
50
169
2364
26890
128
13
995
4468065
36414
49
1466706
3430
443
169
2188
24915
13
996
24694971
75578
53
1719055
3430
553
169
2115
23723
13
997
5313646
35543
34
1338
1110
223
169
2224
24583
13
998
6237355
17262
59
182266
2796
2796
169
2176
25098
13
999
12987240
14270
46
19189
2440
130
169
2186
24210
13
1000
13894731
544009
53
21719
2440
32
169
2279
27638
14
1001
419807
41
12936076
4920
730
196
2783
31626
14
1002
746
57
10698
3185
109
196
3189
36423
14
1003
16464
50
1386889
4006
2766
196
2662
34873
14
1004
7735
46
2724
2275
184
196
3089
36361
14
1005
104482
36
3020
2423
249
196
2884
34211
14
1006
17132
30
9647
3185
187
196
3095
37546
14
1007
87209
78
115718
3472
614
196
2989
35699
14
1008
112162
99
5520
3096
941
196
3101
36719
14
1009
8831
57
1701130
4017
571
196
2633
34323
14
1010
45653
132
1604
1679
144
196
2993
34631
14
1011
26557
51
4327
4782
187
196
2960
32121
14
1012
173860
60
746842
4017
748
196
3136
36138
14
1013
371853
42
1683634
4017
687
196
3073
36035
14
1014
232743
70
111733
3472
267
196
2898
37311
14
1015
42958
71
146493
3472
614
196
3197
38086
14
1016
37453
54
1475413
4017
249
196
3132
38488
14
1017
30209
51
868199
4017
848
196
2673
37292
14
1018
293056
37
14172852
4920
946
196
2926
33915
14
1019
41605
63
1106546
4017
243
196
3066
34651
14
1020
611446
33
5082
1345
495
196
2690
34276
14
1021
1293
91
17406
3185
535
196
3087
37475
14
1022
7499
41
17336
3185
66
196
2393
31012
129
14
1023
9750
45
1327609
4017
839
196
2972
36026
14
1024
228609
36
2,2E+08
6320
2319
196
2912
34826
14
1025
62881
60
1717
3478
144
196
3050
35017
14
1026
457954
34
150440
4017
249
196
2955
36895
14
1027
167462
44
5517
3096
44
196
2776
37653
14
1028
92150
34
102695
3472
249
196
3189
37002
14
1029
28749
31
1431665
4017
2766
196
2547
29098
14
1030
6040
59
15412517
4920
748
196
3094
35059
14
1031
470
52
16558
3185
26
196
3078
35287
14
1032
150103
55
4161
3096
2445
196
2799
37117
14
1033
33930
49
19535
3185
214
196
3107
36927
14
1034
16823
110
22717
3185
44
196
2756
32645
14
1035
35586
55
184423
3472
187
196
2567
30064
14
1036
1024
88
10703
3185
144
196
2975
36545
14
1037
898
53
5320
3096
26
196
3067
34083
14
1038
21833
72
16599
3185
206
196
3067
37342
14
1039
311796
41
9199
3185
44
196
2799
34694
14
1040
193185
67
11642288
4735
1733
196
2989
35784
14
1041
41349
49
5462167
4910
791
196
2723
38029
14
1042
340955
36
6036
3185
26
196
2882
32639
14
1043
38106
72
5009
3096
206
196
3165
37520
14
1044
1200
63
3148
1679
44
196
2597
34802
14
1045
1793
64
5653
3096
206
196
3062
37033
14
1046
62824
46
12577
3185
66
196
3054
37725
14
1047
1739
56
138823
3472
848
196
3054
37086
14
1048
81462
47
4314
3096
206
196
2675
30799
14
1049
99497
39
11821
3185
728
196
2665
31383
14
1050
4236
91
882737
4017
848
196
3014
35938
130
14
1051
81605
60
5978
3096
94
196
3068
36429
14
1052
61996
88
4579
3150
66
196
3107
37294
14
1053
48003
91
4812
3096
730
196
2942
31399
14
1054
102435
46
20512
3185
3741
196
2970
35834
14
1055
5515
42
1855
2820
989
196
2489
28941
14
1056
27887
41
127492
3472
201
196
2681
36287
14
1057
7247
32
6344
3185
292
196
3076
36041
14
1058
38957
45
19441
3185
44
196
2936
33214
14
1059
259537
56
163993
3472
748
196
2932
36028
14
1060
18583
52
1231308
4017
206
196
3102
36002
14
1061
192800
53
12648927
4920
730
196
2793
33297
14
1062
538157
55
19963
3185
465
196
3117
36732
14
1063
4121
52
18642
3185
26
196
2953
37784
14
1064
34442
49
10840
3185
730
196
2792
34420
14
1065
24990
30
87812
3472
267
196
3095
36655
14
1066
16425
46
5312
2342
191
196
2666
32876
14
1067
496161
32
9126
3185
144
196
3002
37492
14
1068
12284
56
62200
3472
206
196
2829
32797
14
1069
322285
31
159392
3472
662
196
3008
35731
14
1070
888
40
170622
3472
1894
196
2390
33078
14
1071
22983
84
17059
3185
144
196
3168
37891
14
1072
147743
35
65865
3472
687
196
3153
36090
14
1073
124576
44
4362
1349
44
196
2647
30724
14
1074
63065
66
1662263
4017
428
196
3032
35198
14
1075
32715
63
19883
3185
1032
196
3105
32633
14
1076
76453
31
4228
1845
92
196
2998
35474
14
1077
7235
40
14863
3185
321
196
3001
35247
14
1078
448722
92
4678
2750
144
196
2814
31692
131
14
1079
357177
38
19593
3185
321
196
2518
35616
14
1080
10123
35
1397
2303
144
196
2791
32928
14
1081
757
30
1034602
4017
614
196
3013
36817
14
1082
113461
39
3154
2915
187
196
2779
34500
14
1083
9284
97
4888
3055
730
196
2787
33983
14
1084
83294
55
17991
3185
144
196
3005
37287
14
1085
3915
60
1379726
4017
848
196
2820
33177
14
1086
179400
124
706
666
44
196
2587
34021
14
1087
65536
30
1557236
4017
667
196
3175
37472
14
1088
11987
37
18665
3185
44
196
3056
37224
14
1089
165498
76
85361
3282
206
196
2952
38031
14
1090
827
32
3432
2985
267
196
2786
32822
14
1091
87250
71
4315
2033
113
196
2461
35959
14
1092
37747
30
4533
3687
129
196
2876
32973
14
1093
1698
98
1610
5372
92
196
2694
35984
14
1094
472303
53
18599711
4920
622
196
3195
37008
14
1095
1010
36
4580
2210
166
196
2789
34290
14
1096
75764
30
1917
1877
44
196
2602
31029
14
1097
387497
69
5357
1820
187
196
2853
34570
14
1098
35732
36
21258
3185
267
196
2762
29751
14
1099
0
42
11188
3185
187
196
3049
36270
14
1100
597833
63
978
621
206
196
2989
36060
15
1101
84818
78
669345
4837
445
225
3735
47339
15
1102
1415
75
9305051
5572
1213
225
3640
49328
15
1103
1015
50
4272
2284
1900
225
3792
46552
15
1104
15195
48
2723
1348
166
225
3424
43894
15
1105
16199
43
9504960
5627
3432
225
3489
48331
15
1106
251128
50
6793
6862
6867
225
3827
48895
132
15
1107
1024661
45
13957944
5627
397
225
3746
48883
15
1108
350064
50
5187
1900
397
225
3460
45364
15
1109
282764
75
1317653
4837
1900
225
3855
50748
15
1110
73161
71
8727
4483
132
225
3753
48980
15
1111
52370
78
1341413
4837
685
225
3023
42874
15
1112
19718
33
3093
2937
132
225
3460
45081
15
1113
186570
58
173361
4377
397
225
3885
47002
15
1114
237800
33
1514156
4837
225
225
3572
45132
15
1115
52986
63
68520
4377
34
225
3786
44624
15
1116
15061
43
763020
4837
492
225
3333
44367
15
1117
124147
51
4954
3605
132
225
3511
46184
15
1118
23457
52
17845925
5627
1202
225
3501
44599
15
1119
147561
40
1384466
4837
336
225
3675
48650
15
1120
882997
32
1807555
4837
287
225
3950
47509
15
1121
477874
52
18851
4167
445
225
3877
50311
15
1122
33180
78
137034
4377
492
225
3402
43298
15
1123
186969
55
32007
4377
512
225
3797
47931
15
1124
316249
55
3100
2284
52
225
3581
46836
15
1125
38322
45
6103
4155
64
225
3455
45280
15
1126
771361
42
484013
4837
94
225
3493
45132
15
1127
161839
38
5714585
5627
438
225
3755
48172
15
1128
30878
64
4528
3220
34
225
3409
45106
15
1129
2573
79
6422
9932
52
225
3567
46926
15
1130
42105
38
157794
4377
330
225
3293
43286
15
1131
51334
42
8940
5388
354
225
3412
42226
15
1132
121311
53
248469
4476
1436
225
3630
44197
15
1133
1337
71
5771
9899
60
225
3638
48111
15
1134
143424
39
87960
4377
316
225
3733
47224
133
15
1135
125671
34
1805
1807
218
225
3410
39332
15
1136
210365
82
38862
4377
132
225
3677
47361
15
1137
743456
44
7059
1101
555
225
3353
41961
15
1138
140274
59
8959
6077
52
225
3533
47773
15
1139
706
81
1536620
4837
753
225
3692
50328
15
1140
0
118
13783175
5627
1387
225
3080
42798
15
1141
7365
52
176655
4377
137
225
3668
47193
15
1142
39687
39
11598948
5627
3785
225
3509
47906
15
1143
136431
64
1373716
4837
1171
225
3948
51000
15
1144
88020
130
4015
2284
64
225
3402
44339
15
1145
15032
87
140427
4377
293
225
3724
48321
15
1146
18849
46
11925
4167
4151
225
3243
44326
15
1147
522997
43
54126
4377
137
225
3755
50054
15
1148
13843
60
15649506
5627
1213
225
3478
47728
15
1149
593951
57
10023
1420
64
225
3689
47447
15
1150
86658
48
8224
4167
94
225
3248
43331
15
1151
54884
82
158943
4377
1155
225
3791
47450
15
1152
34110
72
20332
4167
397
225
3600
46235
15
1153
301700
44
114900
4377
94
225
3584
49920
15
1154
14438
58
135171
4377
555
225
3140
43522
15
1155
15526
96
11602
2442
52
225
3411
40012
15
1156
13741
56
7653
2768
555
225
3474
45747
15
1157
0
40
149685
4377
311
225
3322
43752
15
1158
20495
40
1224076
4837
1010
225
3804
51083
15
1159
38968
39
518807
4837
351
225
3654
46082
15
1160
15896
34
2,17E+08
6867
1245
225
3519
44929
15
1161
55296
43
42159
4377
1375
225
3391
44709
15
1162
419675
59
8953
8548
34
225
3501
45157
134
15
1163
72819
65
18555
4167
351
225
3730
47478
15
1164
7187
75
3938
5170
94
225
3443
50207
15
1165
0
39
7432
8218
354
225
3703
47325
15
1166
314823
33
17324971
5627
1155
225
2999
48566
15
1167
4904
49
1,99E+08
6852
4366
225
3621
49637
15
1168
295389
59
2,1E+08
6867
1245
225
3603
45225
15
1169
784198
82
6565
8713
354
225
3456
45277
15
1170
84231
59
148140
4377
130
225
3414
46858
15
1171
144631
44
20267
4167
4151
225
3622
45561
15
1172
1168
34
1586323
4837
327
225
3907
50436
15
1173
59587
51
182706
4377
135
225
3603
45369
15
1174
6917
135
9882
4167
137
225
3400
46873
15
1175
642
47
149574
4377
397
225
3758
48360
15
1176
49526
61
5758
3175
354
225
3601
45538
15
1177
82250
36
137055
4377
397
225
3624
47174
15
1178
1092
51
28345
4348
1708
225
3628
47629
15
1179
17681
107
5013922
5627
445
225
3948
40900
15
1180
792
48
7515
1446
64
225
3822
48123
15
1181
43082
70
5069
826
34
225
3730
45368
15
1182
0
38
10384
4167
1226
225
3581
49668
15
1183
1413
34
8908
4730
351
225
3529
46376
15
1184
1424
65
5599
6790
763
225
3858
49326
15
1185
13176
39
38046
4377
94
225
3570
47565
15
1186
457185
83
334752
4837
1299
225
3400
44539
15
1187
390809
36
21701
2442
264
225
3926
50473
15
1188
118841
48
124956
4377
351
225
3389
50134
15
1189
1279
49
159348
4377
512
225
3478
44470
15
1190
128721
71
8234
2870
132
225
3996
50353
135
15
1191
148463
32
89409
4377
287
225
3787
49875
15
1192
16691
52
11957074
5539
1155
225
3732
50065
15
1193
32132
33
779990
4837
137
225
3403
49396
15
1194
17392
48
146952
4377
512
225
3530
42312
15
1195
17112
38
12838976
5627
1374
225
3538
43949
15
1196
53731
56
15943045
5627
397
225
3951
50556
15
1197
149837
51
83229
4377
1900
225
3259
48771
15
1198
8287
73
5193
5094
397
225
3509
48189
15
1199
321736
37
149061
4377
555
225
3704
42894
15
1200
122956
85
1562928
4837
137
225
3797
46996
16
1201
443022
69
102362
5551
189
256
4406
63266
16
1202
489333
36
2,05E+08
7706
1034
256
4757
67062
16
1203
60081
44
19495
5434
943
256
4181
57204
16
1204
756648
52
1385381
5922
911
256
4275
59287
16
1205
198252
38
177697
5551
732
256
4531
63152
16
1206
617686
37
165612
5551
208
256
4546
64268
16
1207
516098
62
16821
16075
689
256
4508
62739
16
1208
1046040
52
70359
5551
4563
256
4113
60413
16
1209
284851
56
5228
12377
146
256
4800
65400
16
1210
385205
35
3632
4207
828
256
4380
63264
16
1211
17530
36
1750368
5922
483
256
4566
62776
16
1212
344610
90
1648652
5922
208
256
3716
60263
16
1213
18882
69
19251847
6607
2137
256
4698
66099
16
1214
36855
36
546392
5922
189
256
4678
64307
16
1215
36442
57
17452
3569
146
256
4523
65519
16
1216
163369
47
1645080
5922
3152
256
4066
60152
16
1217
136971
40
85480
5551
46
256
4620
51391
16
1218
14762
53
3344
4322
46
256
4140
51339
136
16
1219
244885
62
9544191
6607
323
256
4385
64968
16
1220
568616
50
17360
16627
3102
256
4549
61002
16
1221
1083
34
13270
5434
3566
256
4522
61300
16
1222
106329
84
8832
5434
442
256
4459
62859
16
1223
253224
42
3490
2110
137
256
4342
58346
16
1224
16668
56
2,16E+08
7706
732
256
4661
62752
16
1225
7571
44
17912554
6607
612
256
4505
59132
16
1226
48069
92
1182411
5922
782
256
4268
64658
16
1227
265276
79
173063
5551
948
256
4691
64983
16
1228
183596
74
18831
5434
646
256
4453
61355
16
1229
89086
40
132337
5551
303
256
4712
66276
16
1230
97405
73
9269
16900
46
256
4608
62915
16
1231
588516
60
114723
5551
948
256
4532
65102
16
1232
7352
56
127470
5428
991
256
4749
59085
16
1233
133303
62
1328010
5922
1289
256
4470
61862
16
1234
64243
34
126265
5551
750
256
4164
64609
16
1235
18827
49
1188716
5922
203
256
4286
63297
16
1236
566210
81
3906518
6607
732
256
4767
65355
16
1237
469481
71
1052540
5922
208
256
4604
61270
16
1238
326318
51
1535624
5922
2904
256
4405
60680
16
1239
16400
66
15462240
6607
2570
256
4862
63738
16
1240
982294
83
804167
5922
495
256
4356
57401
16
1241
1235
39
1,1E+08
7706
850
256
4859
64062
16
1242
1150
71
10031
5161
2570
256
4179
57936
16
1243
451192
70
1193580
5922
189
256
4691
65827
16
1244
4661393
48
942666
5922
732
256
4078
60227
16
1245
1063174
61
7955607
6607
7105
256
4249
64011
16
1246
73397
53
1808019
5922
683
256
4624
63905
137
16
1247
112035
79
13672
3002
46
256
4292
57961
16
1248
205906
43
152395
5551
948
256
4100
59848
16
1249
784369
41
1318295
5922
251
256
4194
65568
16
1250
58628
42
1,51E+09
9219
2131
256
4726
67693
16
1251
11791
47
14796
9753
991
256
4245
59861
16
1252
90462
82
5795
3098
46
256
4583
64558
16
1253
20217
50
12361
1914
189
256
4251
59364
16
1254
728420
58
7380118
6607
732
256
3932
53743
16
1255
409322
41
166151
5551
646
256
4553
62483
16
1256
69033
42
4193
10228
208
256
4377
59926
16
1257
161962
62
147895
5551
526
256
4018
60954
16
1258
58318
73
1406304
5922
256
256
4539
63769
16
1259
1094
82
166198
5551
46
256
4589
59054
16
1260
67421
36
5325
13433
146
256
4492
59246
16
1261
31023
61
16375675
6607
642
256
4437
63902
16
1262
6676
95
1,99E+08
7673
1421
256
4301
66507
16
1263
255994
79
1569729
5922
689
256
4632
61165
16
1264
22719
49
25029
5434
645
256
4655
64446
16
1265
82504
47
186010
5551
146
256
4071
57645
16
1266
430833
84
171254
5551
689
256
4092
61158
16
1267
429095
58
10737676
6607
294
256
4663
61297
16
1268
117622
59
1458857
5922
487
256
4687
53845
16
1269
33149
39
19131623
6607
2163
256
4437
66423
16
1270
1350
80
4614
4207
689
256
4154
56652
16
1271
65848
43
4422
4293
646
256
3971
58609
16
1272
493811
49
18461672
6607
1627
256
4663
63754
16
1273
55439
39
7227
5343
68
256
3864
56607
16
1274
179581
36
5779
3098
732
256
4349
63895
138
16
1275
33238
107
31948
5551
948
256
4504
63705
16
1276
76095
48
14562
18224
146
256
4365
57763
16
1277
5068
47
3164
1109
189
256
4416
60426
16
1278
30228
69
16604426
6550
601
256
4620
63089
16
1279
22034
85
19518142
6607
1615
256
4826
65172
16
1280
254740
41
964043
5922
1722
256
4150
60182
16
1281
258632
35
13996305
6607
1710
256
4452
63917
16
1282
755150
51
163481
5922
184
256
4598
65539
16
1283
97572
38
1282786
5922
208
256
4662
62910
16
1284
99360
70
8008
2039
208
256
4524
60077
16
1285
257293
46
7692
13842
208
256
4308
62317
16
1286
18969
96
1,76E+08
7706
750
256
4425
63801
16
1287
1505
49
11122
4578
111
256
4281
54835
16
1288
10779
165
1378734
5893
411
256
4649
61953
16
1289
219131
66
141568
5551
294
256
4296
61793
16
1290
537782
76
623887
5922
208
256
4698
63512
16
1291
113849
55
14852
9620
856
256
4437
63421
16
1292
42456
41
7268
12698
68
256
4575
61737
16
1293
134761
86
81343
5551
515
256
4127
55790
16
1294
101072
44
19330998
6607
732
256
4352
63829
16
1295
628881
64
9278
9359
3195
256
4421
65598
16
1296
419412
47
5862
5922
616
256
4642
55853
16
1297
110945
65
5494
5551
394
256
4504
59225
16
1298
12627
47
5862
5922
3109
256
4232
60186
16
1299
532781
81
5494
5551
991
256
4065
56469
16
1300
35937
65
9278
9359
3666
256
4688
62233
17
1301
188354
101
322
289
5047
74511
17
1302
1274021
38
237
289
5268
77779
139
17
1303
508119
59
284
289
5536
80534
17
1304
239961
52
289
289
4934
73077
17
1305
110901
53
246
289
5670
82098
17
1306
120718
67
1617
289
5322
70321
17
1307
3304
45
6189
289
5085
76469
17
1308
69186
106
4069
289
5400
80172
17
1309
249997
53
96
289
5252
73644
17
1310
161475
97
2529
289
5491
81241
17
1311
291571
65
356
289
5437
81843
17
1312
0
36
2525
289
5162
70150
17
1313
26829
99
96
289
5562
83427
17
1314
76897
48
36
289
4961
73670
17
1315
12129
67
399
289
5629
83457
17
1316
516873
53
96
289
5371
62981
17
1317
16436
67
557
289
5451
76241
17
1318
375196
104
227
289
5129
71612
17
1319
15069575
62
399
289
4544
75472
17
1320
163065
56
289
289
5280
76854
17
1321
173424
101
1859
289
5444
84242
17
1322
1748191
72
1125
289
5839
82466
17
1323
224838
36
2146
289
5468
82633
17
1324
92122
50
485
289
5009
69702
17
1325
141800
62
134
289
5577
86236
17
1326
250477
134
356
289
5547
81119
17
1327
580584
74
96
289
5405
78170
17
1328
96474
81
4777
289
4266
69955
17
1329
557663
40
399
289
5574
80099
17
1330
315282
62
2453
289
5699
82085
140
17
1331
242403
52
7362
289
5285
76990
17
1332
172613
43
97
289
4794
81865
17
1333
426926
58
744
289
5628
79990
17
1334
91243
47
1145
289
5722
83762
17
1335
85092
141
659
289
5575
83346
17
1336
459337
59
398
289
5589
77846
17
1337
508166
41
353
289
4986
78781
17
1338
557569
77
1859
289
5018
72438
17
1339
437171
37
6006
289
5558
79573
17
1340
342544
40
1022
289
4827
75261
17
1341
591945
91
341
289
4759
75268
17
1342
881916
44
1269
289
5366
79401
17
1343
326863
40
66
289
4937
83590
17
1344
112132
45
96
289
5223
82209
17
1345
8229980
89
1226
289
5051
75265
17
1346
1455504
52
1173
289
5803
84264
17
1347
94633
40
2964
289
5790
86741
17
1348
475550
70
1181
289
5213
75892
17
1349
71380
40
1859
289
5240
79134
17
1350
16884
74
2800
289
5796
85298
17
1351
7787
79
11562
289
5703
81141
17
1352
385781
101
10562
289
5498
78794
17
1353
863385
44
1173
289
5203
84468
17
1354
734541
92
6853
289
5241
82316
17
1355
439892
117
1470
289
5606
80337
17
1356
21520
73
36
289
5089
81416
17
1357
89589
83
356
289
5467
78847
17
1358
191234
68
3215
289
5085
77157
141
17
1359
529861
44
447
289
5122
76775
17
1360
83501
54
1204
289
5063
79257
17
1361
824799
77
246
289
5542
76767
17
1362
53172
102
1069
289
5043
80953
17
1363
40627778
53
399
289
5541
79937
17
1364
3007459
51
2017
289
5682
87095
17
1365
55166
87
353
289
5178
72938
17
1366
58250
60
1173
289
5512
73378
17
1367
684185
51
9626
289
5158
81630
17
1368
6708
60
2270
289
5540
82143
17
1369
413146
76
96
289
5509
83020
17
1370
19814
115
1859
289
5471
78904
17
1371
11822
74
356
289
4918
72130
17
1372
137085
65
1114
289
5400
74727
17
1373
28945
46
1206
289
5328
78350
17
1374
303089
66
356
289
5359
73637
17
1375
1968650
47
557
289
4770
71641
17
1376
658500
39
177
289
5269
70481
17
1377
0
39
96
289
5200
72154
17
1378
150427
45
1471
289
5382
79265
17
1379
606676
50
1318
289
5697
81769
17
1380
255668
96
1859
289
5294
79595
17
1381
411089
40
442
289
5311
78939
17
1382
44567
40
1204
289
5343
79730
17
1383
67903
51
3195
289
5301
80125
17
1384
415074
62
557
289
5404
77261
17
1385
64844
43
246
289
5425
83568
17
1386
8808
66
1859
289
5610
77824
142
17
1387
112428
66
399
289
5252
79353
17
1388
730080
43
356
289
5007
81751
17
1389
12015
62
356
289
5392
78272
17
1390
12969
62
1204
289
5484
76110
17
1391
145757
51
1171
289
5649
81617
17
1392
1902
46
134
289
5341
79065
17
1393
780989
36
1005
289
5105
75218
17
1394
206408
49
289
289
4564
79609
17
1395
87621
85
1859
289
4859
65170
17
1396
295285
44
353
289
5783
86431
17
1397
16284
96
1022
289
5419
80690
17
1398
590032
98
2329
289
5744
83131
17
1399
388736
92
139
289
5659
71393
17
1400
367580
60
356
289
5826
86249
18
1401
1064800
18
1402
165760
18
1403
1604873
18
1404
6135
18
1405
563469
18
1406
998119
18
1407
403409
18
1408
245068
18
1409
625857
18
1410
17269
18
1411
3337896
18
1412
521860
18
1413
317547
18
1414
25097
143
18
1415
105129
18
1416
414301
18
1417
232276
18
1418
10968
18
1419
2304502
18
1420
475940
18
1421
197014
18
1422
1305899
18
1423
19644
18
1424
1836881
18
1425
233661
18
1426
1241655
18
1427
50341
18
1428
71508
18
1429
9316301
18
1430
1246071
18
1431
150949
18
1432
1196400
18
1433
602960
18
1434
910113
18
1435
588005
18
1436
5248615
18
1437
2215447
18
1438
1575972
18
1439
42752
18
1440
613902
18
1441
604573
18
1442
218381
144
18
1443
984524
18
1444
2469025
18
1445
3117030
18
1446
1038121
18
1447
120018
18
1448
39277
18
1449
189940
18
1450
287593
18
1451
502262
18
1452
643507
18
1453
47612
18
1454
2897
18
1455
451966
18
1456
983860
18
1457
774557
18
1458
7602358
18
1459
162040
18
1460
458378
18
1461
34814
18
1462
1264485
18
1463
26167
18
1464
1729559
18
1465
1140673
18
1466
11743
18
1467
723281
18
1468
65754
18
1469
69246
18
1470
38835
145
18
1471
815088
18
1472
106788
18
1473
856245
18
1474
1456
18
1475
1689
18
1476
1753578
18
1477
1178878
18
1478
282203
18
1479
2964216
18
1480
194847
18
1481
3816532
18
1482
73908
18
1483
742995
18
1484
418875
18
1485
281643
18
1486
8255497
18
1487
381530
18
1488
94551
18
1489
121094
18
1490
82227
18
1491
76286
18
1492
756948
18
1493
355553
18
1494
27340
18
1495
649654
18
1496
8883254
18
1497
822242
18
1498
903775
146
18
1499
193586
18
1500
250343
147
Скачать