Реферат: «Применение информационный технологий в теории графов»
Название: «Применение информационный технологий в теории графов» Раздел: Остальные рефераты Тип: реферат | |||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
БЕЛОРУССКИЙ ГОСУДАРСТВЕННЫЙ УНИВЕРСИТЕТ Выпускная работа по Магистрант кафедры УМФ Петрович Роман Александрович Руководители: профессор, доктор физико-математических наук Тышкевич Регина Иосифовна, доцент Кожич Павел Павлович Минск – 2009 г. ОглавлениеСписок обозначений ко всей выпускной работе. 5 Реферат на тему «Применение информационный технологий в теории графов». 6 Глава 1. Некоторые сведения из теории алгоритмов. 7 Глава 2. Элементы теории сложности. 11 Глава 3. Теория сложности в магистерской диссертации. 11 Глава 4. Обзор применения ИТ в теории графов. 13 Глава 5. Обзор библиотеки JGraphT. 14 Глава 6. Обзор библиотеки JGraph. 17 Список литературы к реферату. 22 Предметный указатель к реферату. 23 Интернет ресурсы в предметной области исследования. 24 Действующий личный сайт в WWW... 25 Презентация магистерской диссертации. 32 Список литературы к выпускной работе. 35 Приложение1. Список вопросов для теста по ИТ. 36 Список обозначений ко всей выпускной работеИТ – информационные технологии. ЭВМ – электронно-вычислительная машина. Реферат на тему «Применение информационный технологий в теории графов» .ВведениеРассматриваемый реферат посвящен применению информационных технологий в теории графов. В наше время теория графов приобретает все возрастающий интерес у специалистов самых различных областей науки и техники. Эта привлекательность объясняется не только очень широким разнообразием возможностей ее применения, но и красотой результатов, достигаемых простыми средствами. Известно, что само появление теории графов восходит к началу XVIII века к задаче «О Кёнигсбергских мостах». Эта задача была решена великим математиком того времени Леонардом Эйлером. В современной математике его результат известен как «Лемма о рукопожатиях». Следующий раз про теорию графов «вспомнили» лишь в начале XX века, найдя ее применение в химии (описание строений соединений углеродов), физике (электрические цепи) и конечно же в самой математике. Действительно, в рамках теории графов имеется множество различных направлений; результаты ее формулируются с привлечением понятий теории множеств, топологии, алгебры, но в тоже время методы теории графов нельзя рассматривать как простую совокупность методов этих разделов математики. Теория графов и гиперграфов является эффективным аппаратом формализации современных инженерных и научных задач, как уже сказано, в различных областях знаний. Язык теории графов удобен при проведении системных исследований, описании организации генетических систем. В последнее время большое применение нашла теория графов в современной вычислительной технике и кибернетике: в теоретическом программировании, при проектировании на ЭВМ и сетей ЭВМ, баз данных, систем логического управления [1]. Глава 1. Некоторые сведения из теории алгоритмовОсобый интерес для практики и приложений представляют алгоритмические аспекты задач на графах. На практике важно уметь с помощью ЭВМ находить в графе наибольшее паросочетание и наибольшее независимое множество, строить гамильтонов цикл или гамильтонову цепь, выделять связные или двусвязные компоненты и т. п. Иначе говоря, надо иметь соответствующие алгоритмы, а в конечном счете и программы для ЭВМ. К примеру, связные и двусвязные компоненты применяются при проектировании компьютерных сетей, обеспечивающих высокую степень надежности. Графы в таких задачах – это огромная (сотни и тысячи вершин) структура, поэтому очень важно использовать оптимальные способы хранения данных и оптимальные алгоритмы их обработки. Нетрудно для каждой из упомянутых выше задач разработать алгоритм, реализующий перебор всех возможных вариантов. Такой подход, однако, неприемлем из-за чрезвычайно большого числа этих вариантов. Поэтому нужен не просто алгоритм, а алгоритм, эффективный, причем эффективность алгоритма очень важно уметь оценивать apriori.Для этой цели служит анализ алгоритма. При анализе алгоритма решения какой-либо задачи нас в первую очередь будет интересовать его трудоемкость, под которой мы понимаем время выполнения соответствующей программы па ЭВМ. Ясно, что этот показатель существенно зависит от типа используемой ЭВМ. Для того, чтобы сделать рассуждения о трудоемкости алгоритмов в достаточной мере универсальными, считается, что все вычисления производятся на некой абстрактной вычислительной машине. Такая машина в состоянии выполнять арифметические операции, сравнения, пересылки и операции условной и безусловной передач управления. Эти операции считаются элементарными . Каждая из элементарных операции выполняется за единицу времени и, следовательно, время работы алгоритма равно числу выполненных им элементарных операций. Память абстрактной вычислительной машины состоит из неограниченного числа ячеек, имеющих адреса 1, 2, 3, ..., n . Причем, ко всем ячейкам памяти этой машины есть прямой доступ. При анализе алгоритмов наибольший интерес представляет зависимость времени работы алгоритма от числа вершин и (или) ребер графа. Cчитается, что любое число, независимо от его величины, можно разместить в одной ячейке памяти и каждая ячейка может содержать только одно число. Рассмотрим теперь представление информации в памяти машины. Всякая конечная последовательность элементов произвольной природы называется списком , а число элементов списка — его длиной . Элементами этого списка могут быть числа, буквы алфавита, векторы, матрицы и т. п. В той ситуации, когда, каждый элемент списка помещается в одной ячейке, этот список будем размещать в n последовательных ячейках памяти, где n — длина списка. Такое представление списка обычно называется последовательным , и далее используется только это представление. Пусть А = ||Ai,j || — матрица порядка n . A* =(A11 , A12 , …, A1n , A21 , A22 ,…, A2n , …, An1 , An2 ,…, Ann ) — список ее элементов по строкам. Принцип «одно число — одна ячейка» означает, что матрица порядка n занимает n2 ячеек памяти. Рассмотрим теперь представление графа G в памяти машины. Пусть VG={v1 ,v2 ,…,vn } . Будем пользоваться тремя способами представления. Первый — задание графа матрицей смежности . Если граф взвешенный и w(x, у) обозначает вес ребра xу, то вместо матрицы смежности используется матрица весов W(G)=W . У этой матрицы Wij =w(vi , vj ), если vi ,vj ÎEG . Если же vi vj не является ребром графа G, то полагаем Wij =0 или Wij =∞ — в зависимости от задачи, которую предстоит решить. Из сказанного выше о представлении матрицы в машине следует, что такой способ задания графа требует |G|2 ячеек памяти. Стоит отметить, что в рассматриваемом примере весами ребер могут быть любые вещественные числа. Второй способ — задание графа списком ребер VE={e1 ,e2 ,…,em } , где m=|EG|, ei ÎEG . Поскольку ребро графа можно хранить, используя две ячейки (по одной на каждую концевую вершину), то для хранения всего списка Е достаточно 2т ячеек. Если граф взвешенный, то под каждый элемент списка Е можно отвести три ячейки — две для ребра и одну для его веса, т. е. всего потребуется Зm ячеек. И, наконец, последний способ, который будет использоваться, — представление графа списками смежности . При таком способе каждой вершине vi , ставится в соответствие список Nvi вершин, смежных с vi . Под этот список достаточно отвести deg(vi )+1 ячеек — по одной на каждый элемент и одну ячейку для обозначения конца списка. Кроме того, формируется список N={N1 ,N2 ,…,Nm } , где Ni , — номер ячейки, в которой хранится первый элемент списка Nvi . Следовательно, такой способ представления графа требует ячеек памяти. Если граф G взвешенный, то дли каждой вершины vj , списка Nvi отводится дополнительно одна ячейка, содержащая число w(vi , vj ). Хотя представление графа списком ребер является наиболее экономным «по памяти», оно имеет существенный недостаток. Чтобы определить, содержит ли граф данное ребро, надо просматривать поочередно элементы этого списка, а это может потребовать около 2т элементарных операций. Если же граф задан списками смежности, вычислительные затраты составят не более n+1 таких операций. Представление графа матрицей смежности, требующее наибольших затрат памяти, обеспечивает «прямой доступ» к ребрам графа. Узнать, содержит ли граф ребро vi vj можно, вычислив адрес k = in + j и сравнив М(k) c нулем, где М — массив, в котором построчно размещена матрица смежности графа. Выбор того или иного задания графа зависит от конкретной задачи, которую предстоит решать. Стандартным подходом является то, что во всех рассматриваемых задачах главной частью исходной информации служит граф. Кроме этого, исходные данные могут включить номера одной или нескольких выделенных вершин. Если, например, задача состоит в отыскании цепи, соединяющей две заданные вершины графа, то помимо графа необходимо задать номера этих двух вершин. После того как ко всем исходным данным задачи присвоены конкретные значения, они размещены в памяти ЭВМ, они называются входом задачи . Размером (или длиною) входа считается число ячеек, занятых входом. При анализе алгоритма решения любой задачи математика в первую очередь интересует зависимость времени его работы от размера задачи, т. е. от размера входа. Однако, это время зависит не только от размера входа, но и от других параметров задачи, т. е. время работы алгоритма на входах одинаковой длины может быть не одинаковым. Поясним сказанное на простейшем примере. Пусть элементами списка S={S1 ,S2 ,…,Sm } являются натуральные числа и требуется определить, содержит ли список S число, кратное трем. Очевидный алгоритм решения этой простой задачи состоит в следующем: проверяем поочередно делимость элементов списка S на 3 до тех пор, пока не встретится число кратное трем, или же не будут проверены все элементы S . Время выполнения р таких проверок равно t = 2р (р делений и р изменений адреса). Следовательно, при неизменной длине входа т время работы алгоритма будет изменяться в пределах 2£t£ 2т в зависимости от расположения подходящего элемента s в списке S. Наихудшим будет случай, когда S не содержит чисел, кратных трем, либо когда Sm — единственное такое число. Один из основных подходов к определению понятия «трудоемкость алгоритма» ориентируется именно на такого рода наихудший случай [1]. Глава 2. Элементы теории сложностиТрудоемкость (или сложность ) алгоритма решения данной задачи определяетcя как функция f , ставящая в соответствие каждому натуральному числу п время работы f(n) алгоритма в худшем случае на входах длины n . Иначе говоря, f(n) —максимальное время работы алгоритма по всем входам данной задачи длины п. Анализ эффективности алгоритмов заключается в выяснении вопроса: как быстро растет функция f(n) с ростом n ? При ответе на этот вопрос обычно используют O-символику . Говорят, что неотрицательная функция f(n) не превосходит по порядку функцию g(n), если существует такая константа с, что f(n) <с g(n) для всех n> 0 ; при этом пишут f(n) = O(g(n)). Выражению «трудоемкость (сложность) алгоритма есть O(g(n)) придается именно этот смысл. В частности, трудоемкость O(i) означает, что время работы соответствующего алгоритма не зависит от длины входа. Алгоритм с трудоемкостью О(п), где n — длина входа, называют линейным . Линейный алгоритм ограниченное константой чиcло раз просматривает входную информацию и для подавляющего большинства «естественных» задач является неулучшаемым в смысле трудоемкости. Поэтому отыскание линейного алгоритма для некоторой задачи часто является своего рода «последней точкой» в ее алгоритмическом решении. Алгоритм, сложность которого равна О(пс ), где с — константа, называется полиномиальным . В большинстве случаев эта степень не превосходит трех и оценка сложности алгоритма, как правило, имеет один из следующих видов: O(n3 ), O(n2 ), O(n), O(n log n) . [1] Глава 3. Теория сложности в магистерской диссертацииОдним из подходов к анализу NP -трудных задач, т.е. таких, про которые известно, что для их точного решения не существует полиномиальных алгоритмов, является наложение ограничений на вход исходной задачи и переход к рассмотрению возникающих при этом подзадач. В этом случае часто возникает пограничная область, отделяющая NP -полные подзадачи от полиномиально разрешимых и включающая те подзадачи, сложность которых неизвестна. Естественной целью является максимально возможное сужение этой области. Особых интерес представляют такие ограничения, при которых пограничная область отсутствует. Например, известно, что задача «k -раскраска» решается за полиномиальное время при k £2 и NP -полна при k ³3 . Еще более интересны ограничения, отражающие внутреннюю структуру подаваемых на вход объектов. Так, для задачи 3 -раскраска, известно, что она полиномиально разрешима в классе графов G с максимальной степенью вершин D(G) £3 и является NP -полной при D(G) ³4 . В действительности, в приведеных примерах утверждения о полиномиальной распознаваемости тривиальны. В магистерской диссертации исследуется нетривиальный пример такого рода. Исследуется NP -полная задача распознавания принадлежности графа G классу Ll 3 графов пересечений ребер линейных 3-униформных гиперграфов. Для нее существует порог полиномиальной разрешимости, связанный с минимальной степенью вершин d(G ) тестируемого графа G. А именно, существует такое натуральное число d* , что задача G ÎLl 3 (1) полиномиально разрешима в классе графов G с d (G ) ³ d * и NP -полна при d (G ) £ d * . В настоящее время существует довольно узкая оценка для числа d * : 6£d * £10. А также существует линейный алгоритм, решающий задачу проверки графа на алгоритм, который решает данную задачу в классе графов с d(G) ³10 [2]. Задачей, поставленной в магистерской диссертации, является по возможности уменьшение оценки d(G) за счет сужения рассматриваемых классов графов. Глава 4. Обзор применения ИТ в теории графовПрименение информационных технологий в теории графов можно разделить по следующим группам. 1) Программы, служащие для набора научных статей по теории графов (например, Microsoft Word, TeX). 2) Программы для изображения графов в удобном виде (например, использование автофигур в Microsoft PowerPoint, либо стандартного набора специальных изображений в Microsoft Visio). 3) Программы для подготовки иллюстраций научных статей (например, Adobe Photoshop, Corel Draw). 4) Специальные библиотеки в языках программирования. Начиная от единиц, предоставляющий графический интерфейс пользователю, до сложных библиотек используемых в при реализации алгоритмов в коммерческих приложениях (например, JGraph и JGraphT в Java). Такого рода библиотеки содержат минимально необходимые сущности, например «граф», «ребро», «бинарное дерево», а также стандартный набор алгоритмов: «поиск в ширину», «поиск в глубину», проверка связности графа, бинарный поиск и многое другое, что позволяет прикладному алгоритмисту абстрагироваться от несущественной детализации и перейти непосредственно к реализации алгоритма. 5) Поиск информации в сети Internet. Отметим, что одним из наиболее важных моментов применения ИТ в теории графов является поиск информации. Зачастую бывает очень трудно найти печатный вариант необходимой книги. С помощью глобальной сети Internet эта проблема решается, появляется возможность искать книги и научные статьи по необходимой тематике. А сейчас остановимся более подробно на использовании библиотек JGraphT и JGraph. Глава 5. Обзор библиотеки JGraphT.Сайт производителя этой библиотеки: http://www.jgraph.com/jgraph.html. JGraphT – это open source Java библиотека, которая содержит огромное количество объектов из теории графов и не меньшее количество стандартных алгоритмов. JGraph поддерживает работу со следующими типами графов. 1) Ориентированные и неориентированные графы. 2) Графы с помеченными и непомеченными ребрами. 3) Простые графы, мультиграфы, псевдографы. Несмотря на всю мощь этой библиотеки, она довольно проста в использовании. С помощью JGraphT можно хранить в памяти компьютера объекты многих сложных типов. Для создания графа программист может использовать большой набор функций. Также предусмотрена возможность экспорта созданных объектов в XML-документ и наоборот, создания объектов из специальных XML-документов. Эта библиотека содержит в себе следующий набор пакетов.
Основными достоинствами библиотеки JGraphT являются то, что она: 1) оптимизирована для моделей данных и алгоритмов; 2) разработана для использования в высокопроизводительных приложениях; 3) может работать с графами содержащими миллионы вершин и ребер; 4) может обеспечивать графическую визуализацию данных с помощью библиотеки JGraph. Рассмотрим, к примеру, пакет org.jgrapht.alg. Этот пакет интересен тем, что в нем содержится реализация многих стандартных алгоритмов из теории графов. Пакет содержит в себе следующий набор классов:
Из рассмотренного примера видно, насколько большой функционал у библиотеки JGraphT и насколько сильно он облегчает работу алгоритмиста. Документация по JGraphT содержится по адресу: http://www.jgrapht.org/javadoc. Глава 6. Обзор библиотеки JGraph.Что же касается библиотеки JGraph, то она в свою очередь: 1) является swing-компонентом для построения графического интерфейса пользователя; 2) содержит более сложное API, чем JGraphT, и поэтому для ее правильного и эффективного использования необходимо изучить предоставляемую документацию; 3) производительность кода, написанного с использованием JGraph, является менее быстрой, чем JGraphT, и поэтому эта библиотека более требовательна к ресурсам. Следующий адрес http://jgrapht.sourceforge.net/visualizations.html содержит пример работы библиотеки JGraph. Рисунок 1. На рисунке 1 мы видим граф на четырех вершинах v1, v2, v3, v4 , содержащий ребра v1v2, v2v3, v3v1, v4v3 . Этот написанный на языке Java апплет поддерживает пользовательский интерфейс типа drag and drop, благодаря чему пользователь может упорядочить вершины графа по своему усмотрению:
Рисунок 2 Ниже приведен исходный код рассмотренной выше программы на языке Java. package org.jgrapht.demo; import java.awt.Color; import java.awt.Dimension; import java.awt.Rectangle; import java.util.HashMap; import java.util.Map; import javax.swing.JApplet; import javax.swing.JFrame; import org.jgraph.JGraph; import org.jgraph.graph.DefaultGraphCell; import org.jgraph.graph.GraphConstants; import org.jgrapht.ListenableGraph; import org.jgrapht.ext.JGraphModelAdapter; import org.jgrapht.graph.ListenableDirectedGraph; import org.jgrapht.graph.DefaultEdge; public class JGraphAdapterDemo extends JApplet { private static final Color DEFAULT_BG_COLOR = Color.decode( "#FAFBFF" ); private static final Dimension DEFAULT_SIZE = new Dimension( 530, 320 ); // private JGraphModelAdapter m_jgAdapter; /** * @see java.applet.Applet#init(). */ public void init( ) { // create a JGraphT graph ListenableGraph g = new ListenableDirectedGraph( DefaultEdge.class ); // create a visualization using JGraph , via an adapter m_jgAdapter = new JGraphModelAdapter( g ); JGraph jgraph = new JGraph( m_jgAdapter ); adjustDisplaySettings( jgraph ); getContentPane( ).add( jgraph ); resize( DEFAULT_SIZE ); // add some sample data (graph manipulated via JGraphT ) g.addVertex( "v1" ); g.addVertex( "v2" ); g.addVertex( "v3" ); g.addVertex( "v4" ); g.addEdge( "v1", "v2" ); g.addEdge( "v2", "v3" ); g.addEdge( "v3", "v1" ); g.addEdge( "v4", "v3" ); // position vertices nicely within JGraph component positionVertexAt( "v1", 130, 40 ); positionVertexAt( "v2", 60, 200 ); positionVertexAt( "v3", 310, 230 ); positionVertexAt( "v4", 380, 70 ); // that's all there is to it!... } private void adjustDisplaySettings( JGraph jg ) { jg.setPreferredSize( DEFAULT_SIZE ); Color c = DEFAULT_BG_COLOR; String colorStr = null; try { colorStr = getParameter( "bgcolor" ); } catch( Exception e ) {} if( colorStr != null ) { c = Color.decode( colorStr ); } jg.setBackground( c ); } private void positionVertexAt( Object vertex, int x, int y ) { DefaultGraphCell cell = m_jgAdapter.getVertexCell( vertex ); Map attr = cell.getAttributes( ); Rectangle b = GraphConstants.getBounds( attr ); GraphConstants.setBounds( attr, new Rectangle( x, y, b.width, b.height ) ); Map cellAttr = new HashMap( ); cellAttr.put( cell, attr ); m_jgAdapter.edit( cellAttr ); } } ЗаключениеИз всего выше сказанного следует, что «информационный бум» оставил свой след во многих сферах человеческой жизни. С появлением компьютерных технологий стало возможно решать такие математические задачи, за которые раньше учёные не могли даже взяться именно из-за большой вычислительной сложности таких задач. Да что и говорить, само бурное развитие теории графов во многом обязано именно появлению вычислительных машин. И наоборот, во многом благодаря теории графов стал возможен такой большой скачок в их производительности. Как известно, немаловажным понятием теории графов является понятие алгоритма. Практическое применение алгоритмов связано именно с использованием ЭВМ. Основной целью этой работы являлось применение информационных технологий в теории графов. И это применение, поистине, безгранично. Начиная с текстовых редакторов, редакторов изображений и заканчивая огромным количеством всевозможных библиотек в языках программирования. Список литературы к реферату1. Лекции по теории графов / В.А. Емеличев, О.И. Мельников, В.И. Сарванов, Р.И. Тышкевич. – М.; Наука, 1990. 384 c. 2. Перез-Чернов А.Х., Тышкевич Р.И. К проблеме распознавания реберных графов линейных 3-униформных гиперграфов: предбольшие клики // Труды института математики. 2007. Т.15. № 2. С 78-89. 3. Скумс П.В, Суздаль С.В., Тышкевич Р.И. О пороге полиномиальной разрешимости для задачи распознавания графов пересечений ребер линейных 3-униформных гиперграфов // Докл. НАН Беларуси. 2004. Т.48. № 4. С.29-34. Предметный указатель к реферату«Лемма о рукопожатиях», 4 Adobe Photoshop, 9 Corel Draw, 9 Internet, 14, 18 JGraph, 9, 10, 11, 12, 13 JGraphT, 9, 10, 11, 12, 13 Microsoft PowerPoint, 9 Microsoft Visio, 9 Microsoft Word, 9 NP-полная задача, 8 NP-трудная задача, 8 O-символика, 7 TeX, 9 абстрактная вычислительная машина, 5 вход задачи, 6 граф взвешенный, 5, 6 длина списка, 5 задача «k-раскраска», 8 задача «О Кёнигсбергских мостах», 4 задача 3-раскраска, 8 линейный алгоритм, 7 матрица весов, 5 матрица смежности, 5, 6 ориентированный граф, 6, 19 полиномиальная сложность, 8 полиномиальный алгоритм, 7 последовательное представление списка, 5 сложность, 7, 8 список, 5 список ребер, 6 список смежности, 6 трудоемкость, 7 ЭВМ, 4, 5, 6 элементарная операция, 5 Интернет ресурсы в предметной области исследования1. http://www.jgraph.com – официальный сайт проекта JGraph. 2. http://arxiv.org – сервис для поиска статей по математике, компьютерным наукам, физике, биологии, статистике. 3. http://poiskknig.ru - поисковая машина электронных книг, свободно распространяемых в интернете. Главным приоритетом является образовательная литература, являющаяся базисом научного и технического знания. 4. http://lib.org.by – библиотека научной литературы по математике, компьютерным наукам, физике, инженерным наукам. 5. http://exponenta.ru – образовательный сайт по математике. 6. http://www.vak.org.by/ – сайт Высшей аттестационной комиссии Республики Беларусь. Действующий личный сайт в WWWСсылка на мой личный сайт в сети Internet: http://raman-piatrovich.narod.ru. Граф научных интересов.магистранта Петровича Р.А. Механико-математический факультет. Специальность: 01.01.09 – дискретная математика и математическая кибернетика
Презентация магистерской диссертации.Список литературы к выпускной работе.1. Лекции по теории графов / В.А. Емеличев, О.И. Мельников, В.И. Сарванов, Р.И. Тышкевич. – М.; Наука, 1990. 384 c. 2. Перез-Чернов А.Х., Тышкевич Р.И. К проблеме распознавания реберных графов линейных 3-униформных гиперграфов: предбольшие клики // Труды института математики. 2007. Т.15. № 2. С 78-89. 3. Скумс П.В, Суздаль С.В., Тышкевич Р.И. О пороге полиномиальной разрешимости для задачи распознавания графов пересечений ребер линейных 3-униформных гиперграфов // Докл. НАН Беларуси. 2004. Т.48. № 4. С.29-34. Интернет-источник: http://www.jgraph.com ПриложенияПриложение1. Список вопросов для теста по ИТ.Вопрос 1. <question type="close" id="384"> <text>01 Число 11 в двоичной системе счисления выглядит как:</text> <answers type="request"> <answer id="313759" right="0"> 1111 </answer> <answer id="313760" right="0"> 101 </answer> <answer id="313761" right="1"> 1011 </answer> <answer id="313762" right="0"> 10 </answer> </answers> </question> Вопрос 2. <question type="close" id="384"> <text>01 Какое максимальное количество вершин может иметь простой граф на n вершинах?</text> <answers type="request"> <answer id="313759" right="0"> n/2 </answer> <answer id="313760" right="0"> n^2 </answer> <answer id="313761" right="1"> n(n-1) </answer> <answer id="313762" right="0"> n(n-1)/2 </answer> </answers> </question> |