Проект

Общее

Профиль

Stage-2 » История » Версия 20

Александр Александров, 04.11.2019 15:15

1 1 Александр Александров
h1. План работы
2
3 3 Александр Александров
Работа над тестовым заданием:
4 2 Александр Александров
5 3 Александр Александров
* Схематично отразить работу программы, рассмотреть несколько вариантов работы, где должно быть отражено успех программы или неуспех. Это наглядно покажет как должна работать программа.
6
* Схематично отразить работу программы, рассмотреть несколько вариантов работы, где должны быть отражены успешные и не успешные запросы к сервису. Это наглядно покажет как должна работать программа.
7 1 Александр Александров
* Создание основной бизнес логики.
8 18 Александр Александров
* Создать структуру веб-приложения работающего как REST-сервис.
9 3 Александр Александров
* Покрытие тестами.
10 4 Александр Александров
11
----
12
13
h1. Структура данных.
14
15
h2. Входные данные
16
17
h3. Граф
18
19 11 Александр Александров
Входными данными будет граф G(V,E), где V - множество вершин графа (ноды), E - множество рёбер, соединяющих вершины. Граф не ориентированный. Сама вершина (нода) представляет собой объект, состоящий из уникального имени. Ребро представляет собой объект состоящий из двух ссылок на вершины, которые это ребро соединяет, в данном случае под ссылками подразумевается уникальное имя ноды. В формате JSON это будет выглядеть так:   
20 4 Александр Александров
21
<pre>
22 20 Александр Александров
{"nodes": [{"name":"unique_node_name"}, ...], "edges": [{"nodeOne":"unique_node_one_name", "nodeTwo":"unique_node_one_name"}, ...]}
23 4 Александр Александров
</pre>
24
25
, где
26
27 10 Александр Александров
_{"name":”unique_node_name"}_ - объект описывающий вершину графа (ноду)
28
_{"nodeOne":"unique_node_one_name", "nodeTwo":"unique_node_one_name"}_ - объект описывающий ребро, соединяющее две вершины графа.
29 4 Александр Александров
30 19 Александр Александров
*Графическое представление входных графов*
31 4 Александр Александров
32
{{dmsf_image(134)}}
33
34
Циклический граф
35
36
{{dmsf_image(131)}}
37
38
Ациклический граф
39
40
Входные графы могут содержать циклы, которые нужно исключить по условию задачи.
41 1 Александр Александров
42 19 Александр Александров
*В качестве дополнения (это не входило в основную задачу)*
43
44
Возможность работы с нодами отдельно, т.е. в граф можно добавить ноду или набор нод отдельным запросом
45
46
Входной одиночный объект, описывающий ноду
47
48
<pre>
49
{"name":"unique_node_name"}
50
</pre>
51
52
Входной набор нод
53
54
<pre>
55
[{"name":"unique_node_name"}, {"name":"unique_node_name"}, ...]
56
</pre>
57
58 20 Александр Александров
Возможность работы с рёбрами графа отдельно, т.е. в граф можно добавить ребро или набор рёбер отдельным запросом
59 19 Александр Александров
60
Входной, одиночный объект описывающий ребро графа
61
62
<pre>
63
{"nodeOne":"unique_node_one_name", "nodeTwo":"unique_node_one_name"}
64
</pre>
65
66 20 Александр Александров
Входной набор рёбер
67 19 Александр Александров
68
<pre>
69
[{"nodeOne":"unique_node_one_name", "nodeTwo":"unique_node_one_name"}, {"nodeOne":"unique_node_one_name", "nodeTwo":"unique_node_one_name"}, ...]
70
</pre>
71
72 4 Александр Александров
h3. Вершины графа (Ноды)
73 12 Александр Александров
74 4 Александр Александров
Так же на вход будут подаваться списки вершин графа для проверки связности вершин. Представляет собой простой перечень уникальных имён вершин.
75
В представлении JSON будет выглядеть так:
76
77 12 Александр Александров
<pre>
78 4 Александр Александров
["unique_node_name", "unique_node_name", ...]
79
</pre>
80 12 Александр Александров
81 4 Александр Александров
, где unique_node_name - уникальное имя вершины.
82
83 1 Александр Александров
h2. Структура выходных данных
84
85 19 Александр Александров
При запросе к сервису можно получить следующие данные:
86
87
*Граф целиком*
88
89
<pre>
90
{"nodes":[{"id":1, "name":"unique_name", "counter":0}, ...], "edges":[{"id":1, "nodeOne":"unique_node_name_one", "nodeOne":"unique_node_name_one"}, ...]}
91
</pre>
92
93
94
*Список вершин графа*
95 4 Александр Александров
96
<pre>
97 13 Александр Александров
[{"id":1, "name":"unique_name", "counter":0}, ...]
98 4 Александр Александров
</pre>
99 1 Александр Александров
100 13 Александр Александров
или объект отдельной вершины (информацию по отдельной вершине можно получить выполнив соответствующий запрос, либо по уникальному имени или по идентификатору вершины)
101
102
<pre>
103
{"id":1, "name":"unique_name", "counter":0}
104
</pre>
105
106
,где: id - уникальный идентификатор вершины, name - уникальное имя вершины, counter - счётчик посещения вершины.
107 4 Александр Александров
108 14 Александр Александров
Так же есть возможность получить информацию по рёбрам графа в следующем формате
109
110
Списком
111
112
<pre>
113
[{"id":1, "nodeOne":"unique_node_name_one", "nodeOne":"unique_node_name_one"}, ...]
114
</pre>
115
116
Отдельным объектом
117
118
{"id":1, "nodeOne":"unique_node_name_one", "nodeOne":"unique_node_name_one"}
119
120
,где: id - уникальный идентификатор ребра графа, nodeOne, nodeTwo - уникальное имя узла графа. Запись ребра графа хранит информацию о одной паре узлов.
121
122 4 Александр Александров
h2. Модель хранения данных
123
124
Класс *Node* - описывающий модель вершины графа (ноды). Класс состоит из следующих полей:
125 15 Александр Александров
126
*id* - уникальный идентификатор (нужен для хранения в БД). Присваивается автоматически при  записи в БД, его нельзя изменить из вне, данный параметр только на отдачу из базы.
127 4 Александр Александров
*name* - уникальное имя узла (получаем из json).
128 15 Александр Александров
*counter* - при каждом удачном проходе маршрута через ноду, счётчик ноды увеличивается автоматически, данный параметр только на отдачу из базы, его нельзя заменить из вне.
129 1 Александр Александров
130 4 Александр Александров
131 15 Александр Александров
Класс *Edge* - описывающий модель ребра графа. Ребро графа способно хранить информацию только о одной паре паре узлов. Класс состоит из следующих полей:
132
133
*id* - уникальный идентификатор записи (нужен для хранения в БД). Присваивается автоматически при  записи в БД, его нельзя изменить из вне, данный параметр только на отдачу из базы.
134
*nodeOne* - ссылка на первую ноду
135
*nodeTwo* - ссылка на вторую ноду
136 4 Александр Александров
137
h2. Модель хранения данных в БД
138
139
{{dmsf_image(135)}}
140
141 16 Александр Александров
Связь один-к-одному Одна запись ребра графа хранит две ссылки на разные ноды
142 5 Александр Александров
143 17 Александр Александров
SQL Schema (PostgreSQL notation)
144 4 Александр Александров
145 1 Александр Александров
<pre><code class="sql">
146 16 Александр Александров
DROP TABLE IF EXISTS nodes CASCADE;
147
DROP TABLE IF EXISTS edges;
148
DROP SEQUENCE IF EXISTS global_seq CASCADE;
149
150
CREATE SEQUENCE global_seq START 5000;
151
152
CREATE TABLE nodes (
153
    id INTEGER PRIMARY KEY DEFAULT nextval('global_seq'),
154
    name VARCHAR NOT NULL,
155
    counter INTEGER DEFAULT 0 NOT NULL
156 4 Александр Александров
);
157 16 Александр Александров
CREATE UNIQUE INDEX nodes_unique_name_idx ON nodes(name);
158 4 Александр Александров
159 16 Александр Александров
CREATE TABLE edges (
160
    id INTEGER PRIMARY KEY DEFAULT nextval('global_seq'),
161
    nodeone INT NOT NULL,
162
    nodetwo INT NOT NULL,
163
    FOREIGN KEY (nodeone) REFERENCES nodes(id) ON DELETE CASCADE,
164
    FOREIGN KEY (nodetwo) REFERENCES nodes(id) ON DELETE CASCADE,
165
    CHECK (nodeone <> nodetwo),
166
    CONSTRAINT unique_edge UNIQUE (nodeone, nodetwo)
167 1 Александр Александров
);
168
</code></pre>
Go to top