{"id":201656,"date":"2013-11-11T11:47:04","date_gmt":"2013-11-11T07:47:04","guid":{"rendered":"http:\/\/savepearlharbor.com\/?p=201656"},"modified":"-0001-11-30T00:00:00","modified_gmt":"-0001-11-29T21:00:00","slug":"","status":"publish","type":"post","link":"https:\/\/savepearlharbor.com\/?p=201656","title":{"rendered":"<span class=\"post_title\">Shortest Common Superstring Problem<\/span>"},"content":{"rendered":"<div class=\"content html_format\"> \t\t\t<b>\u041f\u0440\u043e\u0431\u043b\u0435\u043c\u0430 \u043a\u0440\u0430\u0442\u0447\u0430\u0439\u0448\u0435\u0439 \u043e\u0431\u0449\u0435\u0439 \u043d\u0430\u0434\u0441\u0442\u0440\u043e\u043a\u0438<\/b> \u0444\u043e\u0440\u043c\u0443\u043b\u0438\u0440\u0443\u0435\u0442\u0441\u044f \u0441\u043b\u0435\u0434\u0443\u044e\u0449\u0438\u043c \u043e\u0431\u0440\u0430\u0437\u043e\u043c: \u043d\u0430\u0439\u0442\u0438 \u043a\u0440\u0430\u0442\u0447\u0430\u0439\u0448\u0443\u044e \u0441\u0442\u0440\u043e\u043a\u0443, \u0442\u0430\u043a\u0443\u044e, \u0447\u0442\u043e \u043a\u0430\u0436\u0434\u0430\u044f \u0441\u0442\u0440\u043e\u043a\u0430 \u0438\u0437 \u0437\u0430\u0434\u0430\u043d\u043d\u043e\u0433\u043e \u043d\u0430\u0431\u043e\u0440\u0430 \u044f\u0432\u043b\u044f\u043b\u0430\u0441\u044c \u0431\u044b \u0435\u0451 \u043f\u043e\u0434\u0441\u0442\u0440\u043e\u043a\u043e\u0439. \u042d\u0442\u0430 \u043f\u0440\u043e\u0431\u043b\u0435\u043c\u0430 \u0438\u043c\u0435\u0435\u0442 \u043c\u0435\u0441\u0442\u043e \u043a\u0430\u043a \u0432 \u0431\u0438\u043e\u0438\u043d\u0444\u043e\u0440\u043c\u0430\u0442\u0438\u043a\u0435 (\u0437\u0430\u0434\u0430\u0447\u0430 \u0441\u0431\u043e\u0440\u043a\u0438 \u0433\u0435\u043d\u043e\u043c\u0430 \u0432 \u043e\u0431\u0449\u0435\u043c \u0441\u043b\u0443\u0447\u0430\u0435) \u0442\u0430\u043a \u0438 \u0432 \u0441\u0436\u0430\u0442\u0438\u0438 \u0434\u0430\u043d\u043d\u044b\u0445 (\u0432\u043c\u0435\u0441\u0442\u043e \u0434\u0430\u043d\u043d\u044b\u0445 \u0445\u0440\u0430\u043d\u0438\u0442\u044c \u0438\u0445 \u043d\u0430\u0434\u0441\u0442\u0440\u043e\u043a\u0443 \u0438 \u043f\u043e\u0441\u043b\u0435\u0434\u043e\u0432\u0430\u0442\u0435\u043b\u044c\u043d\u043e\u0441\u0442\u044c \u043f\u0430\u0440, \u0432\u0438\u0434\u0430 (\u0438\u043d\u0434\u0435\u043a\u0441 \u0432\u0445\u043e\u0436\u0434\u0435\u043d\u0438\u044f, \u0434\u043b\u0438\u043d\u0430)). <\/p>\n<p>  \u041a\u043e\u0433\u0434\u0430 \u044f \u0438\u0441\u043a\u0430\u043b \u0432 \u0441\u0435\u0442\u0438 \u0438\u043d\u0444\u043e\u0440\u043c\u0430\u0446\u0438\u044e \u043f\u043e \u044d\u0442\u043e\u0439 \u043f\u0440\u043e\u0431\u043b\u0435\u043c\u0435 \u0438 \u0435\u0451 \u0440\u0435\u0448\u0435\u043d\u0438\u044e \u043d\u0430 \u0440\u0443\u0441\u0441\u043a\u043e\u043c \u044f\u0437\u044b\u043a\u0435 \u2014 \u043d\u0430\u0445\u043e\u0434\u0438\u043b\u0430\u0441\u044c \u043b\u0438\u0448\u044c \u043f\u0430\u0440\u0430 \u043f\u043e\u0441\u0442\u043e\u0432 \u043f\u0440\u043e \u0431\u0438\u043e\u0438\u043d\u0444\u043e\u0440\u043c\u0430\u0442\u0438\u043a\u0435, \u0433\u0434\u0435 \u0432\u0441\u043a\u043e\u043b\u044c\u0437\u044c \u0443\u043f\u043e\u043c\u0438\u043d\u0430\u044e\u0442\u0441\u044f \u044d\u0442\u0438 \u0441\u043b\u043e\u0432\u0430. \u041a\u043e\u0434\u0430 (\u043a\u0440\u043e\u043c\u0435 \u0436\u0430\u0434\u043d\u043e\u0433\u043e \u0430\u043b\u0433\u043e\u0440\u0438\u0442\u043c\u0430), \u043a\u043e\u043d\u0435\u0447\u043d\u043e \u0436\u0435, \u0442\u043e\u0436\u0435 \u043d\u0435 \u0431\u044b\u043b\u043e. \u0420\u0430\u0437\u043e\u0431\u0440\u0430\u0432\u0448\u0438\u0441\u044c \u0432 \u043f\u0440\u043e\u0431\u043b\u0435\u043c\u0435, \u044d\u0442\u043e\u0442 \u0444\u0430\u043a\u0442 \u0441\u043f\u043e\u0434\u0432\u0438\u0433 \u043d\u0430 \u0441\u0442\u0430\u0442\u044c\u044e \u0437\u0434\u0435\u0441\u044c.<\/p>\n<p>  \u041e\u0441\u0442\u043e\u0440\u043e\u0436\u043d\u043e, 4 \u043c\u0435\u0433\u0430\u0431\u0430\u0439\u0442\u0430!<br \/>  <a name=\"habracut\"><\/a><br \/>  \u041f\u043e \u0431\u043e\u043b\u044c\u0448\u0435\u0439 \u0447\u0430\u0441\u0442\u0438, \u0441\u0442\u0430\u0442\u044c\u044f \u2014 \u043f\u043e\u043f\u044b\u0442\u043a\u0430 \u043f\u0435\u0440\u0435\u0432\u0435\u0441\u0442\u0438 \u043d\u0430 \u043f\u043e\u043d\u044f\u0442\u043d\u044b\u0439 \u044f\u0437\u044b\u043a, \u043f\u0440\u043e\u0438\u043b\u043b\u044e\u0441\u0442\u0440\u0438\u0440\u043e\u0432\u0430\u0442\u044c, \u043f\u0440\u0438\u043f\u0440\u0430\u0432\u0438\u0442\u044c \u043f\u0440\u0438\u043c\u0435\u0440\u043e\u043c, \u0438, \u043a\u043e\u043d\u0435\u0447\u043d\u043e \u0436\u0435, \u0440\u0435\u0430\u043b\u0438\u0437\u043e\u0432\u0430\u0442\u044c \u043d\u0430 Java 4-\u043f\u0440\u0438\u0431\u043b\u0438\u0436\u0451\u043d\u043d\u044b\u0439 \u0430\u043b\u0433\u043e\u0440\u0438\u0442\u043c \u043a\u043e\u043d\u0441\u0442\u0440\u0443\u0438\u0440\u043e\u0432\u0430\u043d\u0438\u044f \u043d\u0430\u0434\u0441\u0442\u0440\u043e\u043a\u0438 \u0438\u0437 \u043a\u043d\u0438\u0436\u043a\u0438 \u0414\u044d\u043d\u0430 \u0413\u0430\u0441\u0444\u0438\u043b\u0434\u0430 (\u0441\u043c. \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u043d\u043d\u0443\u044e \u043b\u0438\u0442\u0435\u0440\u0430\u0442\u0443\u0440\u0443). \u041d\u043e \u0441\u043d\u0430\u0447\u0430\u043b\u0430 \u043d\u0435\u0431\u043e\u043b\u044c\u0448\u043e\u0435 \u0432\u0432\u0435\u0434\u0435\u043d\u0438\u0435 \u0438 2-\u043f\u0440\u0438\u0431\u043b\u0438\u0436\u0435\u043d\u043d\u044b\u0439, \u0436\u0430\u0434\u043d\u044b\u0439 \u0430\u043b\u0433\u043e\u0440\u0438\u0442\u043c.<\/p>\n<p>  <b>\u0412 \u043f\u0440\u043e\u0441\u0442\u0435\u0439\u0448\u0435\u043c \u0441\u043b\u0443\u0447\u0430\u0435<\/b> (\u0435\u0441\u043b\u0438 \u0431\u044b \u0432 \u043d\u0430\u0437\u0432\u0430\u043d\u0438\u0438 \u043f\u0440\u043e\u0431\u043b\u0435\u043c\u044b \u043d\u0435 \u0431\u044b\u043b\u043e \u0441\u043b\u043e\u0432\u0430 \u201c\u043a\u0440\u0430\u0442\u0447\u0430\u0439\u0448\u0435\u0439\u201d) \u0440\u0435\u0448\u0435\u043d\u0438\u0435\u043c \u0437\u0430\u0434\u0430\u0447\u0438 \u0431\u0443\u0434\u0435\u0442 \u043f\u0440\u043e\u0441\u0442\u043e\u0435 \u043a\u043e\u043d\u043a\u0430\u0442\u0435\u043d\u0438\u0440\u043e\u0432\u0430\u043d\u0438\u0435 \u0432\u0445\u043e\u0434\u043d\u044b\u0445 \u0441\u0442\u0440\u043e\u043a \u0432 \u043f\u0440\u043e\u0438\u0437\u0432\u043e\u043b\u044c\u043d\u043e\u043c \u043f\u043e\u0440\u044f\u0434\u043a\u0435. \u041d\u043e \u043f\u0440\u0438 \u0434\u0430\u043d\u043d\u043e\u0439 \u043f\u043e\u0441\u0442\u0430\u043d\u043e\u0432\u043a\u0435 \u043f\u0440\u043e\u0431\u043b\u0435\u043c\u044b \u043c\u044b \u0438\u043c\u0435\u0435\u043c \u0434\u0435\u043b\u043e \u0441 NP-\u043f\u043e\u043b\u043d\u043e\u0442\u043e\u0439, \u0447\u0442\u043e \u043e\u0437\u043d\u0430\u0447\u0430\u0435\u0442, \u0447\u0442\u043e \u0432 \u043d\u0430\u0441\u0442\u043e\u044f\u0449\u0435\u0435 \u0432\u0440\u0435\u043c\u044f \u043d\u0435 \u0441\u0443\u0449\u0435\u0441\u0442\u0432\u0443\u0435\u0442 \u0430\u043b\u0433\u043e\u0440\u0438\u0442\u043c\u0430, \u0441 \u043f\u043e\u043c\u043e\u0449\u044c\u044e \u043a\u043e\u0442\u043e\u0440\u043e\u0433\u043e \u043c\u043e\u0436\u043d\u043e \u0431\u044b\u043b\u043e \u0431\u044b \u0440\u0435\u0448\u0438\u0442\u044c \u044d\u0442\u0443 \u0437\u0430\u0434\u0430\u0447\u0443 \u043d\u0430 \u043c\u0430\u0448\u0438\u043d\u0435 \u0422\u044c\u044e\u0440\u0438\u043d\u0433\u0430 \u0437\u0430 \u0432\u0440\u0435\u043c\u044f, \u043d\u0435 \u043f\u0440\u0435\u0432\u043e\u0441\u0445\u043e\u0434\u044f\u0449\u0435\u0435 \u043f\u043e\u043b\u0438\u043d\u043e\u043c\u0430 \u043e\u0442 \u0440\u0430\u0437\u043c\u0435\u0440\u0430 \u0434\u0430\u043d\u043d\u044b\u0445.<\/p>\n<p>  <b>\u0412\u0432\u043e\u0434:<\/b> S<sub>1<\/sub>, S<sub>2<\/sub>, \u2026, S<sub>n<\/sub> \u2014 \u043c\u043d\u043e\u0436\u0435\u0441\u0442\u0432\u043e \u0441\u0442\u0440\u043e\u043a \u043a\u043e\u043d\u0435\u0447\u043d\u043e\u0433\u043e \u0430\u043b\u0444\u0430\u0432\u0438\u0442\u0430 E*.<br \/>  <b>\u0412\u044b\u0432\u043e\u0434:<\/b> X \u2014 \u0441\u0442\u0440\u043e\u043a\u0430 \u0430\u043b\u0444\u0430\u0432\u0438\u0442\u0430 E* \u0441\u043e\u0434\u0435\u0440\u0436\u0430\u0449\u0430\u044f \u043a\u0430\u0436\u0434\u0443\u044e \u0441\u0442\u0440\u043e\u043a\u0443 S<sub>1..n<\/sub> \u0432 \u043a\u0430\u0447\u0435\u0441\u0442\u0432\u0435 \u043f\u043e\u0434\u0441\u0442\u0440\u043e\u043a\u0438, \u0433\u0434\u0435 \u0434\u043b\u0438\u043d\u0430 |X| \u043c\u0438\u043d\u0438\u043c\u0438\u0437\u0438\u0440\u043e\u0432\u0430\u043d\u0430.<\/p>\n<p>  <b>\u041f\u0440\u0438\u043c\u0435\u0440.<\/b> \u0412\u043e\u0437\u044c\u043c\u0451\u043c \u043c\u043d\u043e\u0436\u0435\u0441\u0442\u0432\u043e \u0441\u0442\u0440\u043e\u043a S = {abc, cde, eab}. \u0412 \u0441\u043b\u0443\u0447\u0430\u0435 \u0441 \u043a\u043e\u043d\u043a\u0430\u0442\u0435\u043d\u0438\u0440\u043e\u0432\u0430\u043d\u0438\u0435\u043c \u0434\u043b\u0438\u043d\u0430 \u0432\u044b\u0445\u043e\u0434\u043d\u043e\u0439 \u043d\u0430\u0434\u0441\u0442\u0440\u043e\u043a\u0438 \u0431\u0443\u0434\u0435\u0442 9 (X = abccdeeab), \u0447\u0442\u043e, \u043e\u0447\u0435\u0432\u0438\u0434\u043d\u043e, \u043d\u0435 \u043b\u0443\u0447\u0448\u0438\u0439 \u0432\u0430\u0440\u0438\u0430\u043d\u0442, \u0442\u0430\u043a \u043a\u0430\u043a \u0441\u0442\u0440\u043e\u043a\u0438 \u043c\u043e\u0433\u0443\u0442 \u0438\u043c\u0435\u0442\u044c \u0441\u0443\u0444\u0444\u0438\u043a\u0441\u043d\u043e-\u043f\u0440\u0435\u0444\u0438\u043a\u0441\u043d\u043e\u0435 \u0441\u043e\u0432\u043f\u0430\u0434\u0435\u043d\u0438\u0435. \u0414\u043b\u0438\u043d\u0443 \u044d\u0442\u043e\u0433\u043e \u0441\u043e\u0432\u043f\u0430\u0434\u0435\u043d\u0438\u044f \u043c\u044b \u0431\u0443\u0434\u0435\u043c \u043d\u0430\u0437\u044b\u0432\u0430\u0442\u044c <b>overlap<\/b>. (\u0412\u044b\u0431\u043e\u0440 \u0430\u043d\u0433\u043b\u0438\u0439\u0441\u043a\u043e\u0433\u043e \u0441\u043b\u043e\u0432\u0430 \u043f\u0440\u043e\u0438\u0437\u0432\u0435\u0434\u0451\u043d \u043d\u0435\u0441\u043b\u0443\u0447\u0430\u0439\u043d\u043e, \u0442\u0430\u043a \u043a\u0430\u043a \u043a\u043e\u043d\u043a\u0440\u0435\u0442\u043d\u043e\u0433\u043e \u0438 \u043e\u0434\u043d\u043e\u0437\u043d\u0430\u0447\u043d\u043e\u0433\u043e \u043f\u0435\u0440\u0435\u0432\u043e\u0434\u0430 \u043d\u0430 \u0440\u0443\u0441\u0441\u043a\u0438\u0439 \u044f\u0437\u044b\u043a \u043e\u043d\u043e \u043d\u0435 \u0438\u043c\u0435\u0435\u0442. \u0412 \u0440\u0443\u0441\u0441\u043a\u043e\u044f\u0437\u044b\u0447\u043d\u043e\u0439 \u043b\u0438\u0442\u0435\u0440\u0430\u0442\u0443\u0440\u0435 \u043e\u0431\u044b\u0447\u043d\u043e \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u044e\u0442\u0441\u044f \u0442\u0435\u0440\u043c\u0438\u043d\u044b \u043d\u0430\u043b\u043e\u0436\u0435\u043d\u0438\u0435, \u043f\u0435\u0440\u0435\u0441\u0435\u0447\u0435\u043d\u0438\u0435, \u043f\u0435\u0440\u0435\u043a\u0440\u044b\u0442\u0438\u0435 \u0438 \u0441\u0443\u0444\u0444\u0438\u043a\u0441\u043d\u043e-\u043f\u0440\u0435\u0444\u0438\u043a\u0441\u043d\u043e\u0435 \u0441\u043e\u0432\u043f\u0430\u0434\u0435\u043d\u0438\u0435).<\/p>\n<p>  <b>\u041e\u0442\u0441\u0442\u0443\u043f\u043b\u0435\u043d\u0438\u0435.<\/b> \u041f\u043e\u043d\u044f\u0442\u0438\u0435 overlap \u044f\u0432\u043b\u044f\u0435\u0442\u0441\u044f \u043e\u0434\u043d\u0438\u043c \u0438\u0437 \u0432\u0430\u0436\u043d\u0435\u0439\u0448\u0438\u0445 \u0432 \u043f\u0440\u043e\u0446\u0435\u0441\u0441\u0435 \u0440\u0435\u0430\u043b\u0438\u0437\u0430\u0446\u0438\u0438 \u0430\u043b\u0433\u043e\u0440\u0438\u0442\u043c\u043e\u0432 \u043a\u043e\u043d\u0441\u0442\u0440\u0443\u0438\u0440\u043e\u0432\u0430\u043d\u0438\u044f \u043d\u0430\u0434\u0441\u0442\u0440\u043e\u043a. \u0412\u044b\u0447\u0438\u0441\u043b\u0435\u043d\u0438\u0435 overlap\u2019a \u0434\u043b\u044f \u0443\u043f\u043e\u0440\u044f\u0434\u043e\u0447\u0435\u043d\u043d\u043e\u0439 \u043f\u0430\u0440\u044b \u0441\u0442\u0440\u043e\u043a (S<sub>i<\/sub>, S<sub>j<\/sub>) \u0441\u0432\u043e\u0434\u0438\u0442\u0441\u044f \u043a \u043d\u0430\u0445\u043e\u0436\u0434\u0435\u043d\u0438\u044e \u0434\u043b\u0438\u043d\u044b \u043c\u0430\u043a\u0441\u0438\u043c\u0430\u043b\u044c\u043d\u043e\u0433\u043e \u0441\u043e\u0432\u043f\u0430\u0434\u0435\u043d\u0438\u044f \u0441\u0443\u0444\u0444\u0438\u043a\u0441\u0430 \u0441\u0442\u0440\u043e\u043a\u0438 S<sub>i<\/sub> \u0441 \u043f\u0440\u0435\u0444\u0438\u043a\u0441\u043e\u043c \u0441\u0442\u0440\u043e\u043a\u0438 S<sub>j<\/sub>.  <\/p>\n<div style=\"text-align:center;\"><img decoding=\"async\"  src=\"http:\/\/habr.habrastorage.org\/post_images\/d78\/d8d\/6c4\/d78d8d6c40cb88e61b7898cbe0372f4b.jpg\" alt=\"image\"\/><\/div>\n<p>  \u041e\u0434\u0438\u043d \u0438\u0437 \u0441\u043f\u043e\u0441\u043e\u0431\u043e\u0432 \u0437\u0430\u043f\u0440\u043e\u0433\u0440\u0430\u043c\u043c\u0438\u0440\u043e\u0432\u0430\u0442\u044c \u043d\u0430\u0445\u043e\u0436\u0434\u0435\u043d\u0438\u0435 overlap\u2019a \u043f\u0440\u0435\u0434\u0441\u0442\u0430\u0432\u043b\u0435\u043d \u0432 \u0441\u043b\u0435\u0434\u0443\u044e\u0449\u0435\u043c \u043b\u0438\u0441\u0442\u0438\u043d\u0433\u0435.<\/p>\n<pre><code class=\"java\">      \/*       * \u0424\u0443\u043d\u043a\u0446\u0438\u044f \u0432\u044b\u0447\u0438\u0441\u043b\u044f\u0435\u0442 \u043c\u0430\u043a\u0441\u0438\u043c\u0430\u043b\u044c\u043d\u0443\u044e \u0434\u043b\u0438\u043d\u0443 \u0441\u0443\u0444\u0444\u0438\u043a\u0441\u0430 \u0441\u0442\u0440\u043e\u043a\u0438 s1       * \u0441\u043e\u0432\u043f\u0430\u0434\u0430\u044e\u0449\u0435\u0433\u043e \u0441 \u043f\u0440\u0435\u0444\u0438\u043a\u0441\u043e\u043c \u0441\u0442\u0440\u043e\u043a\u0438 s2 (\u0434\u043b\u0438\u043d\u0443 \u043d\u0430\u043b\u043e\u0436\u0435\u043d\u0438\u044f s1 \u043d\u0430 s2)       *\/       private static int overlap(String s1, String s2)       {         int s1last = s1.length() - 1;         int s2len = s2.length();         int overlap = 0;         for (int i = s1last, j = 1; i &gt; 0 && j &lt; s2len; i--, j++)         {           String suff = s1.substring(i);           String pref = s2.substring(0, j);           if (suff.equals(pref)) overlap = j;          }         return overlap;       } <\/code><\/pre>\n<p>  <b>\u0412\u043e\u0437\u0432\u0440\u0430\u0442 \u043a \u043f\u0440\u0438\u043c\u0435\u0440\u0443. <\/b>\u0415\u0441\u043b\u0438 \u043a\u043e\u043d\u043a\u0430\u0442\u0435\u043d\u0438\u0440\u043e\u0432\u0430\u0442\u044c \u0441\u0442\u0440\u043e\u043a\u0438 S = {abc, cde, eab} \u0441 \u0443\u0447\u0451\u0442\u043e\u043c \u0438\u0445 overlap\u2019\u043e\u0432, \u0442\u043e \u043f\u043e\u043b\u0443\u0447\u0438\u043c \u0441\u0442\u0440\u043e\u043a\u0443 X = abcdeab \u0441 \u0434\u043b\u0438\u043d\u043d\u043e\u0439 7, \u043a\u043e\u0442\u043e\u0440\u0430\u044f \u043a\u043e\u0440\u043e\u0447\u0435 \u043f\u0440\u0435\u0434\u044b\u0434\u0443\u0449\u0435\u0439, \u043d\u043e \u043d\u0435 \u0441\u0430\u043c\u0430\u044f \u043a\u043e\u0440\u043e\u0442\u043a\u0430\u044f. \u0421\u0430\u043c\u0430\u044f \u043a\u043e\u0440\u043e\u0442\u043a\u0430\u044f \u0441\u0442\u0440\u043e\u043a\u0430 \u043f\u043e\u043b\u0443\u0447\u0438\u0442\u0441\u044f \u043f\u0440\u0438 \u043a\u043e\u043d\u043a\u0430\u0442\u0435\u043d\u0438\u0440\u043e\u0432\u0430\u043d\u0438\u0438 \u0441\u0442\u0440\u043e\u043a \u0441 \u0443\u0447\u0451\u0442\u043e\u043c overlap\u2019\u043e\u0432 \u0432 \u043f\u043e\u0440\u044f\u0434\u043a\u0435 3-1-2, \u0442\u043e\u0433\u0434\u0430 \u0440\u0435\u0437\u0443\u043b\u044c\u0442\u0438\u0440\u0443\u044e\u0449\u0430\u044f \u0441\u0442\u0440\u043e\u043a\u0430 X = eabcde \u0431\u0443\u0434\u0435\u0442 \u0438\u043c\u0435\u0442\u044c \u0434\u043b\u0438\u043d\u0443 6. \u0422\u0430\u043a\u0438\u043c \u043e\u0431\u0440\u0430\u0437\u043e\u043c, \u043c\u044b \u0441\u0432\u0435\u043b\u0438 \u0437\u0430\u0434\u0430\u0447\u0443 \u043a \u043d\u0430\u0445\u043e\u0436\u0434\u0435\u043d\u0438\u044e \u043e\u043f\u0442\u0438\u043c\u0430\u043b\u044c\u043d\u043e\u0433\u043e \u043f\u043e\u0440\u044f\u0434\u043a\u0430 \u043a\u043e\u043d\u043a\u0430\u0442\u0435\u043d\u0438\u0440\u043e\u0432\u0430\u043d\u0438\u044f \u0441\u0442\u0440\u043e\u043a \u0441 \u0443\u0447\u0451\u0442\u043e\u043c \u0438\u0445 overlap\u2019\u043e\u0432.<\/p>\n<p>  <b>\u041e\u0433\u0440\u0430\u043d\u0438\u0447\u0435\u043d\u0438\u0435.<\/b> \u0412\u0441\u0435 \u0441\u0443\u0449\u0435\u0441\u0442\u0432\u0443\u044e\u0449\u0438\u0435 \u0430\u043b\u0433\u043e\u0440\u0438\u0442\u043c\u044b \u043d\u0430\u0445\u043e\u0436\u0434\u0435\u043d\u0438\u044f \u043a\u0440\u0430\u0442\u0447\u0430\u0439\u0448\u0438\u0445 \u043d\u0430\u0434\u0441\u0442\u0440\u043e\u043a \u043f\u0440\u0435\u0434\u043f\u043e\u043b\u0430\u0433\u0430\u044e\u0442, \u0447\u0442\u043e \u043d\u0438\u043a\u0430\u043a\u0430\u044f \u0441\u0442\u0440\u043e\u043a\u0430 \u0432\u0445\u043e\u0434\u043d\u043e\u0433\u043e \u043d\u0430\u0431\u043e\u0440\u0430 \u043d\u0435 \u044f\u0432\u043b\u044f\u0435\u0442\u0441\u044f \u043f\u043e\u0434\u0441\u0442\u0440\u043e\u043a\u043e\u0439 \u043a\u0430\u043a\u043e\u0439-\u043b\u0438\u0431\u043e \u0434\u0440\u0443\u0433\u043e\u0439 \u0441\u0442\u0440\u043e\u043a\u0438. \u0423\u0434\u0430\u043b\u0435\u043d\u0438\u0435 \u0442\u0430\u043a\u0438\u0445 \u0441\u0442\u0440\u043e\u043a \u043c\u043e\u0436\u0435\u0442 \u0431\u044b\u0442\u044c \u043f\u0440\u043e\u0438\u0437\u0432\u0435\u0434\u0435\u043d\u043e, \u043d\u0430\u043f\u0440\u0438\u043c\u0435\u0440, \u0441 \u043f\u043e\u043c\u043e\u0449\u044c\u044e \u0441\u0443\u0444\u0444\u0438\u043a\u0441\u043d\u043e\u0433\u043e \u0434\u0435\u0440\u0435\u0432\u0430 \u0438, \u043e\u0447\u0435\u0432\u0438\u0434\u043d\u043e, \u043d\u0435 \u0443\u043c\u0430\u043b\u044f\u0435\u0442 \u043e\u0431\u0449\u043d\u043e\u0441\u0442\u0438.<\/p>\n<h2>\u0416\u0430\u0434\u043d\u044b\u0439 \u0430\u043b\u0433\u043e\u0440\u0438\u0442\u043c<\/h2>\n<p>  \u0412 \u044d\u0442\u043e\u043c \u0430\u043b\u0433\u043e\u0440\u0438\u0442\u043c\u0435 \u043d\u0430 \u043a\u0430\u0436\u0434\u043e\u0439 \u0438\u0442\u0435\u0440\u0430\u0446\u0438\u0438 \u043c\u044b \u043f\u044b\u0442\u0430\u0435\u043c\u0441\u044f \u043d\u0430\u0439\u0442\u0438 \u043c\u0430\u043a\u0441\u0438\u043c\u0430\u043b\u044c\u043d\u044b\u0439 overlap \u0434\u0432\u0443\u0445 \u043b\u044e\u0431\u044b\u0445 \u0441\u0442\u0440\u043e\u043a \u0438 \u0441\u043b\u0438\u0442\u044c \u0438\u0445 \u0432 \u043e\u0434\u043d\u0443. \u041c\u044b \u043d\u0430\u0434\u0435\u0435\u043c\u0441\u044f, \u0447\u0442\u043e \u0440\u0435\u0437\u0443\u043b\u044c\u0442\u0430\u0442 \u044d\u0442\u043e\u0433\u043e \u0430\u043b\u0433\u043e\u0440\u0438\u0442\u043c\u0430 \u0431\u0443\u0434\u0435\u0442 \u0431\u043b\u0438\u0437\u043a\u043e \u043f\u0440\u0438\u0431\u043b\u0438\u0436\u0451\u043d \u043a \u0444\u0430\u043a\u0442\u0438\u0447\u0435\u0441\u043a\u0438 \u043e\u043f\u0442\u0438\u043c\u0430\u043b\u044c\u043d\u043e\u043c\u0443.<\/p>\n<p>  1. \u041f\u043e\u043a\u0430 S \u0441\u043e\u0434\u0435\u0440\u0436\u0438\u0442 \u0431\u043e\u043b\u0435\u0435 \u043e\u0434\u043d\u043e\u0439 \u0441\u0442\u0440\u043e\u043a\u0438, \u043d\u0430\u0445\u043e\u0434\u0438\u043c \u0434\u0432\u0435 \u0441\u0442\u0440\u043e\u043a\u0438 \u0441 \u043c\u0430\u043a\u0441\u0438\u043c\u0430\u043b\u044c\u043d\u044b\u043c overlap\u2019\u043e\u043c \u0438 \u0441\u043b\u0438\u0432\u0430\u0435\u043c \u0438\u0445 \u0432 \u043e\u0434\u043d\u0443 (\u043d\u0430\u043f\u0440\u0438\u043c\u0435\u0440, ABCD + CDEFG = ABCDEFG).<br \/>  2. \u0412\u043e\u0437\u0432\u0440\u0430\u0449\u0430\u0435\u043c \u043e\u0434\u043d\u0443 \u043e\u0441\u0442\u0430\u0432\u0448\u0443\u044e\u0441\u044f \u0432 S \u0441\u0442\u0440\u043e\u043a\u0443.<\/p>\n<p>  \u041f\u0440\u0438\u043c\u0435\u0440 \u0440\u0435\u0430\u043b\u0438\u0437\u0430\u0446\u0438\u0438 \u044d\u0442\u043e\u0433\u043e \u0430\u043b\u0433\u043e\u0440\u0438\u0442\u043c\u0430 \u043f\u0440\u0435\u0434\u0441\u0442\u0430\u0432\u043b\u0435\u043d \u0432 \u0441\u043b\u0435\u0434\u0443\u044e\u0449\u0435\u043c \u043b\u0438\u0441\u0442\u0438\u043d\u0433\u0435.<\/p>\n<pre><code class=\"java\">      \/*       * \u0424\u0443\u043d\u043a\u0446\u0438\u044f \u0441\u043b\u0438\u0432\u0430\u0435\u0442 \u0441\u0442\u0440\u043e\u043a\u0438 \u0441 \u043c\u0430\u043a\u0441\u0438\u043c\u0430\u043b\u044c\u043d\u044b\u043c \u043d\u0430\u043b\u043e\u0436\u0435\u043d\u0438\u0435\u043c \u0434\u043e \u0442\u0435\u0445 \u043f\u043e\u0440,       * \u043f\u043e\u043a\u0430 \u043d\u0435 \u043e\u0441\u0442\u0430\u043d\u0435\u0442\u0441\u044f \u0435\u0434\u0438\u043d\u0441\u0442\u0432\u0435\u043d\u043d\u0430\u044f \u0441\u0442\u0440\u043e\u043a\u0430 (\u043e\u0431\u0449\u0430\u044f \u043d\u0430\u0434\u0441\u0442\u0440\u043e\u043a\u0430).        *\/       public static String createSuperString(ArrayList&lt;String&gt; strings)       {         while (strings.size() &gt; 1)         {           int maxoverlap = 0;           String msi = strings.get(0), msj = strings.get(1);           for (String si : strings)             for (String sj : strings)             {                if (si.equals(sj)) continue;                int curoverlap = overlap(si, sj);                 if (curoverlap &gt; maxoverlap)                {                  maxoverlap = curoverlap;                  msi = si; msj = sj;                }             }            strings.add(merge(msi, msj, maxoverlap));           strings.remove(msi);           strings.remove(msj);         }         return strings.get(0);       } <\/code><\/pre>\n<p>  \u0412 \u044d\u0442\u043e\u043c \u043b\u0438\u0441\u0442\u0438\u043d\u0433\u0435 \u043f\u043e\u044f\u0432\u0438\u043b\u0430\u0441\u044c \u0434\u0440\u0443\u0433\u0430\u044f \u043f\u0440\u043e\u0441\u0442\u0430\u044f \u0444\u0443\u043d\u043a\u0446\u0438\u044f merge, \u043a\u043e\u0442\u043e\u0440\u0430\u044f \u0441\u043b\u0438\u0432\u0430\u0435\u0442 \u0434\u0432\u0435 \u0441\u0442\u0440\u043e\u043a\u0438 \u0432 \u043e\u0434\u043d\u0443 \u0441 \u0443\u0447\u0451\u0442\u043e\u043c \u0438\u0445 overlap\u2019a. \u0422\u0430\u043a \u043a\u0430\u043a \u043f\u043e\u0441\u043b\u0435\u0434\u043d\u0438\u0439 \u0443\u0436\u0435 \u0431\u044b\u043b \u0432\u044b\u0447\u0438\u0441\u043b\u0435\u043d, \u043b\u043e\u0433\u0438\u0447\u043d\u043e \u043f\u0440\u043e\u0441\u0442\u043e \u043f\u0435\u0440\u0435\u0434\u0430\u0442\u044c \u0435\u0433\u043e \u0432 \u043a\u0430\u0447\u0435\u0441\u0442\u0432\u0435 \u043f\u0430\u0440\u0430\u043c\u0435\u0442\u0440\u0430.<\/p>\n<pre><code class=\"java\">      \/*       * \u0424\u0443\u043d\u043a\u0446\u0438\u044f \u0441\u043b\u0438\u0432\u0430\u0435\u0442 \u0441\u0442\u0440\u043e\u043a\u0438 s1 \u0438 s2 \u043d\u0430 \u0434\u043b\u0438\u043d\u0443 len, \u0432\u044b\u0447\u0438\u0441\u043b\u0435\u043d\u043d\u0443\u044e \u0441       * \u043f\u043e\u043c\u043e\u0449\u044c\u044e \u0444\u0443\u043d\u043a\u0446\u0438\u0438 overlap(s1, s2)       *\/       private static String merge(String s1, String s2, int len)       {         s2 = s2.substring(len);         return s1 + s2;       } <\/code><\/pre>\n<p>  \u041e\u0434\u0438\u043d \u043f\u0440\u0438\u043c\u0435\u0440 (<b>\u0445\u0443\u0434\u0448\u0438\u0439 \u0441\u043b\u0443\u0447\u0430\u0439<\/b>):<br \/>   \u25cf <b>\u0412\u0432\u043e\u0434<\/b>: S = {\u00abab<sup>k<\/sup>\u00bb, \u00abb<sup>k<\/sup>c\u00bb, \u00abb<sup>k+1<\/sup>\u00bb}<br \/>   \u25cf <b>\u0412\u044b\u0432\u043e\u0434<\/b> \u0436\u0430\u0434\u043d\u043e\u0433\u043e \u0430\u043b\u0433\u043e\u0440\u0438\u0442\u043c\u0430: \u00abab<sup>k<\/sup>cb<sup>k+1<\/sup>\u00bb \u0441 \u0434\u043b\u0438\u043d\u043e\u0439 4+4k<br \/>   \u25cf <b>\u0412\u044b\u0432\u043e\u0434<\/b> \u043e\u043f\u0442\u0438\u043c\u0430\u043b\u044c\u043d\u043e\u0433\u043e \u0430\u043b\u0433\u043e\u0440\u0438\u0442\u043c\u0430: \u00abab<sup>k+1<\/sup>c\u00bb \u0441 \u0434\u043b\u0438\u043d\u043e\u0439 4+2k<\/p>\n<p>  <b>\u041a\u043e\u044d\u0444\u0444\u0438\u0446\u0438\u0435\u043d\u0442 \u043f\u0440\u0438\u0431\u043b\u0438\u0436\u0435\u043d\u0438\u044f<\/b> \u0438\u0441\u0445\u043e\u0434\u044f \u0438\u0437 \u0445\u0443\u0434\u0448\u0435\u0433\u043e \u0441\u043b\u0443\u0447\u0430\u044f <img decoding=\"async\" src=\"http:\/\/habrastorage.org\/storage3\/930\/889\/555\/930889555c28433f0136ecba65c6089d.gif\" alt=\"image\"\/><\/p>\n<h2>4-\u043f\u0440\u0438\u0431\u043b\u0438\u0436\u0451\u043d\u043d\u044b\u0439 \u0430\u043b\u0433\u043e\u0440\u0438\u0442\u043c \u0411\u043b\u044e\u043c\u0430-\u042f\u043d\u0433\u0430-\u041b\u0438-\u0422\u0440\u043e\u043c\u043f\u0430-\u042f\u043d\u043d\u0430\u043a\u0430\u043a\u0438\u0441\u0430<\/h2>\n<p>  \u0412\u043e\u043e\u0431\u0449\u0435 \u0433\u043e\u0432\u043e\u0440\u044f, \u0443 \u044d\u0442\u043e\u0433\u043e \u0430\u043b\u0433\u043e\u0440\u0438\u0442\u043c\u0430 \u043d\u0435\u0442 \u043d\u0430\u0437\u0432\u0430\u043d\u0438\u044f \u0438 \u0442\u0430\u043a, \u043a\u0430\u043a \u044f, \u0435\u0433\u043e \u043d\u0438\u043a\u0442\u043e \u043d\u0435 \u043d\u0430\u0437\u044b\u0432\u0430\u0435\u0442. \u041d\u0430\u0437\u044b\u0432\u0430\u0435\u0442\u0441\u044f \u043e\u043d \u043f\u0440\u043e\u0441\u0442\u043e 4-\u043f\u0440\u0438\u0431\u043b\u0438\u0436\u0451\u043d\u043d\u044b\u0439 \u0430\u043b\u0433\u043e\u0440\u0438\u0442\u043c \u043a\u043e\u043d\u0441\u0442\u0440\u0443\u0438\u0440\u043e\u0432\u0430\u043d\u0438\u044f \u043a\u0440\u0430\u0442\u0447\u0430\u0439\u0448\u0435\u0439 \u043d\u0430\u0434\u0441\u0442\u0440\u043e\u043a\u0438. \u041d\u043e \u0442\u0430\u043a \u043a\u0430\u043a \u0435\u0433\u043e \u043f\u0440\u0438\u0434\u0443\u043c\u0430\u043b\u0438 \u0411\u043b\u044e\u043c, \u042f\u043d\u0433, \u041b\u0438, \u0422\u0440\u043e\u043c\u043f \u0438 \u042f\u043d\u043d\u0430\u043a\u0430\u043a\u0438\u0441, \u043f\u043e\u0447\u0435\u043c\u0443 \u0431\u044b \u043d\u0435 \u0434\u0430\u0442\u044c \u0442\u0430\u043a\u043e\u0439 \u0437\u0430\u0433\u043e\u043b\u043e\u0432\u043e\u043a?<\/p>\n<p>  <b>\u0414\u043b\u044f \u043d\u0430\u0433\u043b\u044f\u0434\u043d\u043e\u0441\u0442\u0438<\/b>, \u0432\u043e \u0432\u0440\u0435\u043c\u044f \u0440\u0430\u0437\u0431\u043e\u0440\u0430 \u0430\u043b\u0433\u043e\u0440\u0438\u0442\u043c\u0430 \u044f \u0431\u0443\u0434\u0443 \u043f\u0440\u0438\u0432\u043e\u0434\u0438\u0442\u044c \u043f\u0440\u0438\u043c\u0435\u0440 \u043f\u043e\u0441\u0442\u0440\u043e\u0435\u043d\u0438\u044f \u043d\u0430\u0434\u0441\u0442\u0440\u043e\u043a\u0438 \u0434\u043b\u044f \u043d\u0430\u0431\u043e\u0440\u0430 <b>S = {S<sub>0<\/sub>: \u201ccde\u201d, S<sub>1<\/sub>: \u201cabc\u201d, S<sub>2<\/sub>: \u201ceab\u201d, S<sub>3<\/sub>: \u201cfgh\u201d, S<sub>4<\/sub>: \u201cghf\u201d, S<sub>5<\/sub>: \u201ched\u201d}<\/b>.<\/p>\n<p>  <b>\u041e\u0441\u043d\u043e\u0432\u043d\u043e\u0439 \u0438\u0434\u0435\u0435\u0439 <\/b>\u0430\u043b\u0433\u043e\u0440\u0438\u0442\u043c\u0430 \u044f\u0432\u043b\u044f\u0435\u0442\u0441\u044f \u043d\u0430\u0445\u043e\u0436\u0434\u0435\u043d\u0438\u0435 \u043f\u043e\u043a\u0440\u044b\u0442\u0438\u044f \u0446\u0438\u043a\u043b\u0430\u043c\u0438 \u043c\u0438\u043d\u0438\u043c\u0430\u043b\u044c\u043d\u043e\u0439 \u043f\u043e\u043b\u043d\u043e\u0439 \u0434\u043b\u0438\u043d\u044b \u0434\u043b\u044f \u043f\u043e\u043b\u043d\u043e\u0433\u043e \u043d\u0430\u043f\u0440\u0430\u0432\u043b\u0435\u043d\u043d\u043e\u0433\u043e \u0432\u0437\u0432\u0435\u0448\u0435\u043d\u043d\u043e\u0433\u043e \u0433\u0440\u0430\u0444\u0430, \u0432\u0435\u0440\u0448\u0438\u043d\u0430\u043c\u0438 \u043a\u043e\u0442\u043e\u0440\u043e\u0433\u043e \u044f\u0432\u043b\u044f\u044e\u0442\u0441\u044f \u0441\u0442\u0440\u043e\u043a\u0438 \u0437\u0430\u0434\u0430\u043d\u043d\u043e\u0433\u043e \u043d\u0430\u0431\u043e\u0440\u0430, \u0430 \u0432\u0435\u0441 \u0440\u0435\u0431\u0440\u0430 \u0438\u0437 S<sub>i<\/sub> \u0432 S<sub>j<\/sub> \u0440\u0430\u0432\u0435\u043d overlap(S<sub>i<\/sub>, S<sub>j<\/sub>) \u0434\u043b\u044f \u0432\u0441\u0435\u0445 i, j.<\/p>\n<p>  \u0413\u0440\u0430\u0444 \u0434\u043b\u044f \u043d\u0430\u0448\u0435\u0433\u043e \u043f\u0440\u0438\u043c\u0435\u0440\u0430 (\u0432\u0435\u0440\u0448\u0438\u043d\u044b \u0434\u043b\u044f \u0432\u0438\u0434\u0438\u043c\u043e\u0441\u0442\u0438 \u043f\u043e\u0434\u043f\u0438\u0441\u0430\u043d\u044b i \u0432\u043c\u0435\u0441\u0442\u043e S<sub>i<\/sub>):  <\/p>\n<div style=\"text-align:center;\"><img decoding=\"async\"  src=\"http:\/\/habrastorage.org\/storage3\/01f\/3d4\/800\/01f3d4800a37c23fd858d34b526b727a.jpg\" alt=\"image\"\/><\/div>\n<p>  \u0412 \u0441\u0432\u043e\u0435\u0439 \u0440\u0435\u0430\u043b\u0438\u0437\u0430\u0446\u0438\u0438 \u044f \u0431\u0443\u0434\u0443 \u043f\u0440\u0435\u0434\u0441\u0442\u0430\u0432\u043b\u044f\u0442\u044c \u044d\u0442\u043e\u0442 \u0433\u0440\u0430\u0444 \u043a\u0430\u043a <b>\u043c\u0430\u0442\u0440\u0438\u0446\u0443 \u0441\u043c\u0435\u0436\u043d\u043e\u0441\u0442\u0438<\/b>, \u043a\u043e\u0442\u043e\u0440\u0430\u044f \u0431\u0443\u0434\u0435\u0442 \u0444\u043e\u0440\u043c\u0438\u0440\u043e\u0432\u0430\u0442\u044c\u0441\u044f \u0431\u0430\u043d\u0430\u043b\u044c\u043d\u044b\u043c \u043e\u0431\u0440\u0430\u0437\u043e\u043c, \u043f\u043e\u043a\u0430\u0437\u0430\u043d\u043d\u043e\u043c \u0432 \u0441\u043b\u0435\u0434\u0443\u044e\u0449\u0435\u043c \u043b\u0438\u0441\u0442\u0438\u043d\u0433\u0435 (\u0432 \u043f.16.17 [1] \u0414. \u0413\u0430\u0441\u0444\u0438\u043b\u0434 \u0443\u0442\u0432\u0435\u0440\u0436\u0434\u0430\u0435\u0442, \u0447\u0442\u043e \u043c\u0430\u0442\u0440\u0438\u0446\u0443 \u043c\u043e\u0436\u043d\u043e \u0444\u043e\u0440\u043c\u0438\u0440\u043e\u0432\u0430\u0442\u044c \u044d\u0444\u0444\u0435\u043a\u0442\u0438\u0432\u043d\u0435\u0435, \u043d\u043e \u0441\u043f\u043e\u0441\u043e\u0431 \u0444\u043e\u0440\u043c\u0438\u0440\u043e\u0432\u0430\u043d\u0438\u044f \u044d\u0442\u043e\u0439 \u043c\u0430\u0442\u0440\u0438\u0446\u044b \u043d\u0435 \u0432\u043b\u0438\u044f\u0435\u0442 \u043d\u0430 \u0440\u0430\u0441\u0441\u043c\u043e\u0442\u0440\u0435\u043d\u0438\u0435 \u0434\u0430\u043d\u043d\u043e\u0433\u043e \u0430\u043b\u0433\u043e\u0440\u0438\u0442\u043c\u0430).<\/p>\n<pre><code class=\"java\">         int n = strings.size();                   \/\/ \u0412\u044b\u0447\u0438\u0441\u043b\u0435\u043d\u0438\u0435 \u043c\u0430\u0442\u0440\u0438\u0446\u044b overlap'\u043e\u0432 \u0434\u043b\u044f \u0432\u0441\u0435\u0445           \/\/ \u0443\u043f\u043e\u0440\u044f\u0434\u043e\u0447\u0435\u043d\u043d\u044b\u0445 \u043f\u0430\u0440 (Si, Sj).          int[][] overlaps = new int[n][n];          for (int i = 0; i &lt; n; i++)             for (int j = 0; j &lt; n; j++)                overlaps[i][j] = overlap(strings.get(i), strings.get(j)); <\/code><\/pre>\n<p>  \u0414\u043b\u044f \u043d\u0430\u0448\u0435\u0433\u043e \u043f\u0440\u0438\u043c\u0435\u0440\u0430 \u043c\u0430\u0442\u0440\u0438\u0446\u0430 \u0441\u043c\u0435\u0436\u043d\u043e\u0441\u0442\u0438 \u0431\u0443\u0434\u0435\u0442 \u0432\u044b\u0433\u043b\u044f\u0434\u0435\u0442\u044c \u0442\u0430\u043a:  <\/p>\n<div style=\"text-align:center;\"><img decoding=\"async\"  src=\"http:\/\/habrastorage.org\/storage3\/a92\/516\/879\/a9251687992964bba3243edbc9c700ac.jpg\" alt=\"image\"\/><\/div>\n<p>  \u041f\u043e\u0441\u043b\u0435 \u0442\u043e\u0433\u043e, \u043a\u0430\u043a \u043c\u0430\u0442\u0440\u0438\u0446\u0430 \u0441\u043c\u0435\u0436\u043d\u043e\u0441\u0442\u0438 \u043f\u043e\u0441\u0442\u0440\u043e\u0435\u043d\u0430, \u0432\u0441\u0442\u0430\u0451\u0442 \u043d\u0435\u043e\u0431\u0445\u043e\u0434\u0438\u043c\u043e\u0441\u0442\u044c \u043d\u0430\u0439\u0442\u0438 \u043f\u043e\u043a\u0440\u044b\u0442\u0438\u0435 \u0446\u0438\u043a\u043b\u0430\u043c\u0438 \u043c\u0438\u043d\u0438\u043c\u0430\u043b\u044c\u043d\u043e\u0439 \u043f\u043e\u043b\u043d\u043e\u0439 \u0434\u043b\u0438\u043d\u044b. \u0422\u0430\u043a\u043e\u0435 \u043f\u043e\u043a\u0440\u044b\u0442\u0438\u0435 \u043c\u043e\u0436\u043d\u043e \u043d\u0430\u0439\u0442\u0438, \u0441\u0432\u043e\u0434\u044f \u044d\u0442\u0443 \u0437\u0430\u0434\u0430\u0447\u0443 \u043a \u201c\u0437\u0430\u0434\u0430\u0447\u0435 \u043e \u043d\u0430\u0437\u043d\u0430\u0447\u0435\u043d\u0438\u044f\u0445\u201d. \u0418\u0442\u0430\u043a, \u0437\u0430\u0434\u0430\u0447\u0435\u0439 \u0441\u0442\u0430\u043b\u043e \u043d\u0430\u0439\u0442\u0438 \u043f\u043e\u043b\u043d\u043e\u0435 \u043d\u0430\u0437\u043d\u0430\u0447\u0435\u043d\u0438\u0435 \u043c\u0430\u043a\u0441\u0438\u043c\u0430\u043b\u044c\u043d\u043e\u0433\u043e \u0432\u0435\u0441\u0430 (\u043a\u0430\u043a \u043e\u043a\u0430\u0437\u0430\u043b\u043e\u0441\u044c, \u044d\u0442\u043e\u0442 \u0448\u0430\u0433 \u0430\u043b\u0433\u043e\u0440\u0438\u0442\u043c\u0430 \u0437\u0430\u043d\u0438\u043c\u0430\u0435\u0442 \u0434\u043e\u043c\u0438\u043d\u0430\u043d\u0442\u043d\u043e\u0435 \u0432\u0440\u0435\u043c\u044f). \u0411\u044b\u0441\u0442\u0440\u0435\u0435 \u0438 \u043f\u0440\u043e\u0449\u0435 ([1] \u043f.16.19.13) \u044d\u0442\u043e \u043d\u0430\u0437\u043d\u0430\u0447\u0435\u043d\u0438\u0435 \u043c\u043e\u0436\u043d\u043e \u043d\u0430\u0439\u0442\u0438 \u0436\u0430\u0434\u043d\u044b\u043c \u043c\u0435\u0442\u043e\u0434\u043e\u043c.<\/p>\n<p>  <b>\u0416\u0430\u0434\u043d\u043e\u0435 \u043d\u0430\u0437\u043d\u0430\u0447\u0435\u043d\u0438\u0435<\/b> ([1] \u043f.16.19.13)<\/p>\n<p>  \u0418\u0441\u0445\u043e\u0434\u043d\u044b\u0435 \u0434\u0430\u043d\u043d\u044b\u0435: \u043c\u0430\u0442\u0440\u0438\u0446\u0430 A \u0440\u0430\u0437\u043c\u0435\u0440\u043e\u043c k \u00d7 k. <br \/>  \u0420\u0435\u0437\u0443\u043b\u044c\u0442\u0430\u0442: \u043f\u043e\u043b\u043d\u043e\u0435 \u043d\u0430\u0437\u043d\u0430\u0447\u0435\u043d\u0438\u0435 M.<\/p>\n<ol>\n<li>\u041f\u043e\u043b\u043e\u0436\u0438\u0442\u044c M = \u00d8 \u0438 \u043e\u0431\u044a\u044f\u0432\u0438\u0442\u044c \u0432\u0441\u0435 \u043a\u043b\u0435\u0442\u043a\u0438 A \u0434\u043e\u0441\u0442\u0443\u043f\u043d\u044b\u043c\u0438.<\/li>\n<li> while \u0432 A \u0435\u0441\u0442\u044c \u0434\u043e\u0441\u0442\u0443\u043f\u043d\u044b\u0435 \u043a\u043b\u0435\u0442\u043a\u0438 do begin<br \/> \n<ol>\n<li>\u0421\u0440\u0435\u0434\u0438 \u0434\u043e\u0441\u0442\u0443\u043f\u043d\u044b\u0445 \u043a\u043b\u0435\u0442\u043e\u043a A \u0432\u044b\u0431\u0440\u0430\u0442\u044c \u043a\u043b\u0435\u0442\u043a\u0443 (i, j) \u043d\u0430\u0438\u0431\u043e\u043b\u044c\u0448\u0435\u0433\u043e \u0432\u0435\u0441\u0430.<\/li>\n<li>\u041f\u043e\u043c\u0435\u0441\u0442\u0438\u0442\u044c \u043a\u043b\u0435\u0442\u043a\u0443 (i, j) \u0432 M \u0438 \u0441\u0434\u0435\u043b\u0430\u0442\u044c \u043a\u043b\u0435\u0442\u043a\u0438 \u0432 \u0441\u0442\u0440\u043e\u0447\u043a\u0435 i \u0438 \u0441\u0442\u043e\u043b\u0431\u0446\u0435 j \u043d\u0435\u0434\u043e\u0441\u0442\u0443\u043f\u043d\u044b\u043c\u0438.<\/li>\n<li>end;<\/li>\n<\/ol>\n<\/li>\n<li>\u0412\u044b\u0434\u0430\u0442\u044c \u043f\u043e\u043b\u043d\u043e\u0435 \u043d\u0430\u0437\u043d\u0430\u0447\u0435\u043d\u0438\u0435 M.<\/li>\n<\/ol>\n<p>  \u041f\u0440\u0435\u0434\u0441\u0442\u0430\u0432\u0438\u0442\u044c M \u0432 \u043a\u043e\u0434\u0435 \u043c\u043e\u0436\u043d\u043e \u0432 \u0432\u0438\u0434\u0435 \u043c\u0430\u0441\u0441\u0438\u0432\u0430 (int[] M = new int[k]) \u0438 \u043f\u0435\u0440\u0432\u0443\u044e \u0447\u0430\u0441\u0442\u044c \u0438\u043d\u0441\u0442\u0440\u0443\u043a\u0446\u0438\u0438 2.2 \u0442\u0440\u0430\u043a\u0442\u043e\u0432\u0430\u0442\u044c \u043a\u0430\u043a M[i] = j; \u0442\u0430\u043a \u043a\u0430\u043a \u0432 \u043f\u043e\u043b\u043d\u043e\u043c \u043d\u0430\u0437\u043d\u0430\u0447\u0435\u043d\u0438\u0438 \u043a\u0430\u0436\u0434\u043e\u0435 \u0447\u0438\u0441\u043b\u043e \u043e\u0442 0 \u0434\u043e k \u0432\u0441\u0442\u0440\u0435\u0447\u0430\u0435\u0442\u0441\u044f \u0440\u043e\u0432\u043d\u043e \u043e\u0434\u0438\u043d \u0440\u0430\u0437 \u043a\u0430\u043a \u0438\u043d\u0434\u0435\u043a\u0441 \u0441\u0442\u0440\u043e\u043a\u0438 \u0438 \u0440\u043e\u0432\u043d\u043e \u043e\u0434\u0438\u043d \u0440\u0430\u0437 \u043a\u0430\u043a \u0438\u043d\u0434\u0435\u043a\u0441 \u0441\u0442\u043e\u043b\u0431\u0446\u0430.<\/p>\n<p>  \u041f\u0440\u0438\u043c\u0435\u0440 \u0440\u0435\u0430\u043b\u0438\u0437\u0430\u0446\u0438\u0438 \u0432\u044b\u0447\u0438\u0441\u043b\u0435\u043d\u0438\u044f \u043f\u043e\u043b\u043d\u043e\u0433\u043e \u043d\u0430\u0437\u043d\u0430\u0447\u0435\u043d\u0438\u044f \u043f\u0440\u0435\u0434\u0441\u0442\u0430\u0432\u043b\u0435\u043d \u0432 \u0441\u043b\u0435\u0434\u0443\u044e\u0449\u0435\u043c \u043b\u0438\u0441\u0442\u0438\u043d\u0433\u0435.<\/p>\n<pre><code class=\"java\">      \/*        * \u0424\u0443\u043d\u043a\u0446\u0438\u044f, \u0432\u044b\u0447\u0438\u0441\u043b\u044f\u044e\u0449\u0430\u044f \u043f\u043e\u043b\u043d\u043e\u0435 \u043d\u0430\u0437\u043d\u0430\u0447\u0435\u043d\u0438\u0435 \u043c\u0430\u043a\u0441\u0438\u043c\u0430\u043b\u044c\u043d\u043e\u0433\u043e        * \u0432\u0435\u0441\u0430 \u0436\u0430\u0436\u043d\u044b\u043c \u043c\u0435\u0442\u043e\u0434\u043e\u043c. \u0412\u0440\u0435\u043c\u044f - O(k*k*log(k))        *\/              private static int[] assignment(int[][] a)       {          int n = a.length;          boolean[][] notallow = new boolean[n][n];                   int[] m = new int[n];                   while (true)          {             int max = -1, maxi = -1, maxj = -1;                        for (int i = 0; i &lt; n; i++)             {                for (int j = 0; j &lt; n; j++)                {                   if (notallow[i][j]) continue;                   if (a[i][j] &gt; max)                   {                      max = a[i][j];                      maxi = i; maxj = j;                   }                }             }                        if (max == -1) break;                        m[maxi] = maxj;                        for (int i = 0; i &lt; n; i++)             {                notallow[maxi][i] = true;                notallow[i][maxj] = true;             }          }          return m;       } <\/code><\/pre>\n<p>  \u041f\u043e\u0448\u0430\u0433\u043e\u0432\u043e\u0435 \u0432\u044b\u0447\u0438\u0441\u043b\u0435\u043d\u0438\u0435 \u043f\u043e\u043b\u043d\u043e\u0433\u043e \u043d\u0430\u0437\u043d\u0430\u0447\u0435\u043d\u0438\u044f \u043c\u0430\u043a\u0441\u0438\u043c\u0430\u043b\u044c\u043d\u043e\u0433\u043e \u0432\u0435\u0441\u0430 \u0436\u0430\u0434\u043d\u044b\u043c \u043c\u0435\u0442\u043e\u0434\u043e\u043c \u0434\u043b\u044f \u043d\u0430\u0448\u0435\u0433\u043e \u043f\u0440\u0438\u043c\u0435\u0440\u0430:<\/p>\n<div style=\"text-align:center;\"><img decoding=\"async\"  src=\"http:\/\/habrastorage.org\/storage3\/f9a\/9c9\/b01\/f9a9c9b01ab27ca78033b0311bc5c98d.gif\" alt=\"image\"\/><\/div>\n<p>  \u0422\u0435\u043f\u0435\u0440\u044c, \u043a\u043e\u0433\u0434\u0430 \u0432\u044b\u0447\u0438\u0441\u043b\u0435\u043d\u043e \u043f\u043e\u043b\u043d\u043e\u0435 \u043d\u0430\u0437\u043d\u0430\u0447\u0435\u043d\u0438\u0435 \u043c\u0430\u043a\u0441\u0438\u043c\u0430\u043b\u044c\u043d\u043e\u0433\u043e \u0432\u0435\u0441\u0430, \u043d\u0435\u043e\u0431\u0445\u043e\u0434\u0438\u043c\u043e \u0432\u044b\u0447\u0438\u0441\u043b\u0438\u0442\u044c <b>\u043f\u043e\u043a\u0440\u044b\u0442\u0438\u0435 \u0446\u0438\u043a\u043b\u0430\u043c\u0438 <\/b>\u043c\u0438\u043d\u0438\u043c\u0430\u043b\u044c\u043d\u043e\u0439 \u043f\u043e\u043b\u043d\u043e\u0439 \u0434\u043b\u0438\u043d\u044b. \u0414\u043b\u044f \u044d\u0442\u043e\u0433\u043e \u043d\u0443\u0436\u043d\u043e:<\/p>\n<p>  \u0432\u0437\u044f\u0432 \u0437\u0430 \u043d\u0430\u0447\u0430\u043b\u043e \u043b\u044e\u0431\u043e\u0439 (\u043b\u043e\u0433\u0438\u0447\u043d\u043e \u2013 \u043d\u0443\u043b\u0435\u0432\u043e\u0439) \u0438\u043d\u0434\u0435\u043a\u0441 \u043f\u043e\u043b\u043d\u043e\u0433\u043e \u043d\u0430\u0437\u043d\u0430\u0447\u0435\u043d\u0438\u044f, \u043f\u043e\u043b\u043e\u0436\u0438\u0442\u044c \u0435\u0433\u043e \u0432 \u0446\u0438\u043a\u043b, \u043f\u043e\u043c\u0435\u0442\u0438\u0442\u044c \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u043d\u043d\u044b\u043c \u0438 \u043f\u043e\u0441\u043c\u043e\u0442\u0440\u0435\u0442\u044c, \u0440\u0430\u0432\u043d\u044f\u0435\u0442\u0441\u044f \u043b\u0438 \u0435\u0433\u043e \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u0435 \u0438\u043d\u0434\u0435\u043a\u0441\u0443 \u043d\u0430\u0447\u0430\u043b\u0430 \u0446\u0438\u043a\u043b\u0430? \u0415\u0441\u043b\u0438 \u0434\u0430 \u2013 \u0437\u0430\u043a\u043e\u043d\u0447\u0438\u0442\u044c \u0446\u0438\u043a\u043b, \u043f\u043e\u043b\u043e\u0436\u0438\u0442\u044c \u0435\u0433\u043e \u0432 \u043f\u043e\u043a\u0440\u044b\u0442\u0438\u0435 \u0446\u0438\u043a\u043b\u0430\u043c\u0438 \u0438 \u043d\u0430\u0447\u0430\u0442\u044c \u043d\u043e\u0432\u044b\u0439 \u0446\u0438\u043a\u043b, \u0432\u0437\u044f\u0432 \u0437\u0430 \u043d\u0430\u0447\u0430\u043b\u043e \u043f\u0435\u0440\u0432\u044b\u0439 \u043d\u0435\u043f\u043e\u043c\u0435\u0447\u0435\u043d\u043d\u044b\u0439 \u044d\u043b\u0435\u043c\u0435\u043d\u0442. \u0415\u0441\u043b\u0438 \u043d\u0435\u0442 \u2013 \u0432\u0437\u044f\u0442\u044c \u044d\u0442\u043e \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u0435 \u0437\u0430 \u0438\u043d\u0434\u0435\u043a\u0441 \u0438 \u043f\u043e\u0432\u0442\u043e\u0440\u0438\u0442\u044c \u043f\u0440\u043e\u0446\u0435\u0434\u0443\u0440\u0443, \u043f\u043e\u043a\u0430 \u0432\u0441\u0435 \u044d\u043b\u0435\u043c\u0435\u043d\u0442\u044b \u043d\u0435 \u0441\u0442\u0430\u043d\u0443\u0442 \u043f\u043e\u043c\u0435\u0447\u0435\u043d\u044b.<\/p>\n<p>  \u041f\u0440\u0435\u0434\u0441\u0442\u0430\u0432\u043b\u0435\u043d\u0438\u0435 \u043f\u043e\u043a\u0440\u044b\u0442\u0438\u044f \u0446\u0438\u043a\u043b\u0430\u043c\u0438 \u0432 \u043f\u0430\u043c\u044f\u0442\u0438 \u043c\u043e\u0436\u043d\u043e \u043e\u0440\u0433\u0430\u043d\u0438\u0437\u043e\u0432\u0430\u0442\u044c \u043a\u0430\u043a <b>\u0441\u043f\u0438\u0441\u043e\u043a \u0441\u043f\u0438\u0441\u043a\u043e\u0432 \u0438\u043d\u0434\u0435\u043a\u0441\u043e\u0432 \u0441\u0442\u0440\u043e\u043a.<\/b><\/p>\n<p>  \u041b\u0438\u0441\u0442\u0438\u043d\u0433 \u0430\u043b\u0433\u043e\u0440\u0438\u0442\u043c\u0430 (assign \u2013 \u043f\u043e\u043b\u043d\u043e\u0435 \u043d\u0430\u0437\u043d\u0430\u0447\u0435\u043d\u0438\u0435):<\/p>\n<pre><code class=\"java\">         \/\/ \u041d\u0430\u0445\u043e\u0436\u0434\u0435\u043d\u0438\u0435 \u043f\u043e\u043a\u0440\u044b\u0442\u0438\u044f \u0446\u0438\u043a\u043b\u0430\u043c\u0438 \u043c\u0438\u043d\u0438\u043c\u0430\u043b\u044c\u043d\u043e\u0439 \u043f\u043e\u043b\u043d\u043e\u0439 \u0434\u043b\u0438\u043d\u044b          \/\/ \u0434\u043b\u044f \u043f\u043e\u043b\u043d\u043e\u0433\u043e \u043d\u0430\u0437\u043d\u0430\u0447\u0435\u043d\u0438\u044f assign          ArrayList&lt;ArrayList&lt;Integer&gt;&gt; cycles              = new ArrayList&lt;ArrayList&lt;Integer&gt;&gt;();          ArrayList&lt;Integer&gt; cycle = new ArrayList&lt;Integer&gt;();          boolean[] mark = new boolean[assign.length];                   for (int i = 0; i &lt; assign.length; i++)          {             if (mark[i]) continue;                        cycle.add(i);             mark[i] = true;                        if (assign[i] == cycle.get(0))             {                cycles.add(cycle);                cycle = new ArrayList&lt;Integer&gt;();                i = 0;             }             else             {                i = assign[i] - 1;             }          } <\/code><\/pre>\n<p>  \u0414\u043b\u044f \u043d\u0430\u0448\u0435\u0433\u043e \u043f\u0440\u0438\u043c\u0435\u0440\u0430 \u043d\u0430\u0445\u043e\u0436\u0434\u0435\u043d\u0438\u0435 \u043f\u043e\u043a\u0440\u044b\u0442\u0438\u044f \u0446\u0438\u043a\u043b\u0430\u043c\u0438 \u0431\u0443\u0434\u0435\u0442 \u0432\u044b\u0433\u043b\u044f\u0434\u0435\u0442\u044c \u0441\u043b\u0435\u0434\u0443\u044e\u0449\u0438\u043c \u043e\u0431\u0440\u0430\u0437\u043e\u043c:<\/p>\n<div style=\"text-align:center;\"><img decoding=\"async\"  src=\"http:\/\/habrastorage.org\/storage3\/437\/7f1\/12a\/4377f112a405a3eda016dc6a13adf965.gif\" alt=\"image\"\/><\/div>\n<p>  \u041f\u043e\u043b\u0443\u0447\u0438\u0432\u0448\u0435\u0435\u0441\u044f \u043f\u043e\u043a\u0440\u044b\u0442\u0438\u0435 \u0446\u0438\u043a\u043b\u0430\u043c\u0438 \u043c\u043e\u0436\u043d\u043e \u043e\u0442\u043e\u0431\u0440\u0430\u0437\u0438\u0442\u044c \u043d\u0430 \u0438\u0437\u043d\u0430\u0447\u0430\u043b\u044c\u043d\u043e\u043c \u0433\u0440\u0430\u0444\u0435, \u043e\u0441\u0442\u0430\u0432\u0438\u0432 \u043d\u0430 \u043d\u0451\u043c \u0442\u043e\u043b\u044c\u043a\u043e \u0442\u0435 \u0440\u0451\u0431\u0440\u0430, \u043a\u043e\u0442\u043e\u0440\u044b\u0435 \u043f\u043e\u043f\u0430\u043b\u0438 \u0432 \u043f\u043e\u043a\u0440\u044b\u0442\u0438\u0435.  <\/p>\n<div style=\"text-align:center;\"><img decoding=\"async\"  src=\"http:\/\/habrastorage.org\/storage3\/28f\/dea\/aae\/28fdeaaae06443779239b0c71b7cffa9.jpg\" alt=\"image\"\/><\/div>\n<p>  <b>\u0421\u0431\u043e\u0440\u043a\u0430.<\/b> \u0422\u0435\u043f\u0435\u0440\u044c, \u043a\u043e\u0433\u0434\u0430 \u0432\u0441\u0435 \u0446\u0438\u043a\u043b\u044b \u0432 \u043f\u043e\u043a\u0440\u044b\u0442\u0438\u0438 \u0432\u044b\u0447\u0438\u0441\u043b\u0435\u043d\u044b, \u043c\u043e\u0436\u043d\u043e \u043f\u0440\u0438\u0441\u0442\u0443\u043f\u0430\u0442\u044c \u043a \u0441\u0431\u043e\u0440\u043a\u0435, \u043d\u0435\u043f\u043e\u0441\u0440\u0435\u0434\u0441\u0442\u0432\u0435\u043d\u043d\u043e, \u043d\u0430\u0434\u0441\u0442\u0440\u043e\u043a\u0438. <\/p>\n<p>  \u0414\u043b\u044f \u044d\u0442\u043e\u0433\u043e \u043f\u043e\u043d\u0430\u0434\u043e\u0431\u0438\u0442\u0441\u044f \u0444\u0443\u043d\u043a\u0446\u0438\u044f prefix, \u043a\u043e\u0442\u043e\u0440\u0430\u044f \u043f\u0440\u0438\u043d\u0438\u043c\u0430\u0435\u0442 \u0441\u0442\u0440\u043e\u043a\u0438 S<sub>1<\/sub> \u0438 S<sub>2<\/sub> \u0438 \u0432\u043e\u0437\u0432\u0440\u0430\u0449\u0430\u0435\u0442 \u0441\u0442\u0440\u043e\u043a\u0443 S<sub>1<\/sub>, \u043e\u0431\u0440\u0435\u0437\u0430\u043d\u043d\u0443\u044e \u0441\u043f\u0440\u0430\u0432\u0430 \u043d\u0430 overlap(S<sub>1<\/sub>, S<sub>2<\/sub>) \u0441\u0438\u043c\u0432\u043e\u043b\u043e\u0432. \u041d\u043e \u0442\u0430\u043a \u043a\u0430\u043a \u0432\u0441\u0435 overlap\u2019\u044b \u0431\u044b\u043b\u0438 \u043d\u0430\u043c\u0438 \u0434\u0430\u0432\u043d\u043e \u043f\u043e\u0441\u0447\u0438\u0442\u0430\u043d\u044b, \u0442\u043e \u0444\u0443\u043d\u043a\u0446\u0438\u044e \u043c\u043e\u0436\u043d\u043e \u043d\u0430\u043f\u0438\u0441\u0430\u0442\u044c \u0442\u0430\u043a, \u0447\u0442\u043e\u0431\u044b \u043e\u043d\u0430 \u043f\u0440\u0438\u043d\u0438\u043c\u0430\u043b\u0430 \u0442\u043e\u043b\u044c\u043a\u043e \u043e\u0434\u043d\u0443 \u0441\u0442\u0440\u043e\u043a\u0443 \u0438 \u043a\u043e\u043b\u0438\u0447\u0435\u0441\u0442\u0432\u043e \u0441\u0438\u043c\u0432\u043e\u043b\u043e\u0432, \u043d\u0430 \u043a\u043e\u0442\u043e\u0440\u043e\u0435 \u0435\u0451 \u043d\u0443\u0436\u043d\u043e \u0443\u043a\u043e\u0440\u043e\u0442\u0438\u0442\u044c.<\/p>\n<pre><code class=\"java\">      \/*        * \u0424\u0443\u043d\u043a\u0446\u0438\u044f \u0432\u043e\u0437\u0432\u0440\u0430\u0449\u0430\u0435\u0442 \u0441\u0442\u0440\u043e\u043a\u0443 s1, \u043e\u0431\u0440\u0435\u0437\u0430\u043d\u043d\u0443\u044e \u0441\u043f\u0440\u0430\u0432\u0430        * \u043d\u0430 ov \u0441\u0438\u043c\u0432\u043e\u043b\u043e\u0432        *\/       private static String prefix(String s1, int ov)       {          return s1.substring(0, s1.length() - ov);       } <\/code><\/pre>\n<p>  \u0422\u0435\u043f\u0435\u0440\u044c \u0434\u043b\u044f \u043a\u0430\u0436\u0434\u043e\u0433\u043e \u0446\u0438\u043a\u043b\u0430 C<sub>i<\/sub> = {S<sub>1<\/sub>, S<sub>2<\/sub>, \u2026, S<sub>k-1<\/sub>, S<sub>k<\/sub>} \u043d\u0435\u043e\u0431\u0445\u043e\u0434\u0438\u043c\u043e \u0441\u043e\u0441\u0442\u0430\u0432\u0438\u0442\u044c \u043d\u0430\u0434\u0441\u0442\u0440\u043e\u043a\u0443 X<sub>Ci<\/sub> = prefix(S<sub>1<\/sub>, overlap(S<sub>1<\/sub>, S<sub>2<\/sub>)) ++ prefix(S<sub>2<\/sub>, overlap(S<sub>2<\/sub>, S\u2026)) ++ prefix(S\u2026, overlap(S\u2026, S<sub>k-1<\/sub>)) ++ S<sub>k<\/sub>.<\/p>\n<p>  \u041f\u0440\u043e\u0431\u043b\u0435\u043c\u0430 \u0441\u043e\u0441\u0442\u043e\u0438\u0442 \u0432 \u0442\u043e\u043c, \u0447\u0442\u043e, \u0442\u0430\u043a \u043a\u0430\u043a \u0446\u0438\u043a\u043b\u044b \u0432 \u043f\u043e\u043a\u0440\u044b\u0442\u0438\u0438 \u2013 \u044d\u0442\u043e <b>\u0446\u0438\u043a\u043b\u044b<\/b> \u2014 \u0437\u043d\u0430\u0447\u0438\u0442, \u043c\u044b \u043c\u043e\u0436\u0435\u043c \u0438\u0445 \u0446\u0438\u043a\u043b\u0438\u0447\u0435\u0441\u043a\u0438 \u043a\u0440\u0443\u0442\u0438\u0442\u044c \u0438 \u043d\u0435\u043f\u043e\u043d\u044f\u0442\u043d\u043e, \u0441 \u043a\u0430\u043a\u043e\u0439 \u0441\u0442\u0440\u043e\u043a\u0438 \u043d\u0430\u0447\u0430\u0442\u044c \u043a\u043e\u043d\u0441\u0442\u0440\u0443\u0438\u0440\u043e\u0432\u0430\u043d\u0438\u0435 \u043d\u0430\u0434\u0441\u0442\u0440\u043e\u043a\u0438 X<sub>Ci<\/sub>. \u041e\u0442\u0432\u0435\u0442 \u043e\u043a\u0430\u0437\u044b\u0432\u0430\u0435\u0442\u0441\u044f \u043f\u0440\u043e\u0441\u0442 \u2013 \u043d\u0443\u0436\u043d\u043e \u0441\u0434\u0432\u0438\u043d\u0443\u0442\u044c \u0446\u0438\u043a\u043b \u0442\u0430\u043a, \u0447\u0442\u043e\u0431\u044b <b>\u043c\u0438\u043d\u0438\u043c\u0438\u0437\u0438\u0440\u043e\u0432\u0430\u0442\u044c<\/b> overlap \u043f\u043e\u0441\u043b\u0435\u0434\u043d\u0435\u0439 \u0438 \u043f\u0435\u0440\u0432\u043e\u0439 \u0441\u0442\u0440\u043e\u043a\u0438.<\/p>\n<p>  \u0420\u0430\u0441\u0441\u043c\u043e\u0442\u0440\u0438\u043c \u043f\u0435\u0440\u0432\u044b\u0439 \u0446\u0438\u043a\u043b \u0446\u0438\u043a\u043b\u0438\u0447\u0435\u0441\u043a\u043e\u0433\u043e \u043f\u043e\u043a\u0440\u044b\u0442\u0438\u044f \u0438\u0437 \u043f\u0440\u0438\u043c\u0435\u0440\u0430.  <\/p>\n<div style=\"text-align:center;\"><img decoding=\"async\"  src=\"http:\/\/habrastorage.org\/storage3\/170\/a0b\/6ef\/170a0b6ef18b75dac1e453f4713a3232.jpg\" alt=\"image\"\/><\/div>\n<p>  \u0415\u0441\u043b\u0438 \u043d\u0435 \u043c\u0438\u043d\u0438\u043c\u0438\u0437\u0438\u0440\u043e\u0432\u0430\u0442\u044c overlap \u043f\u043e\u0441\u043b\u0435\u0434\u043d\u0435\u0439 \u0438 \u043f\u0435\u0440\u0432\u043e\u0439 \u0441\u0442\u0440\u043e\u043a\u0438, \u0430 \u0432\u0437\u044f\u0442\u044c C<sub>0<\/sub> = {1, 0, 2}, \u0442\u043e \u043d\u0430\u0434\u0441\u0442\u0440\u043e\u043a\u043e\u0439 \u0431\u0443\u0434\u0435\u0442 X<sub>C0<\/sub> = abc ++ cde ++ eab = abcdeab, \u043e\u0447\u0435\u0432\u0438\u0434\u043d\u043e, \u043d\u0435 \u0441\u0430\u043c\u0430\u044f \u043a\u043e\u0440\u043e\u0442\u043a\u0430\u044f \u0438\u0437 \u0432\u043e\u0437\u043c\u043e\u0436\u043d\u044b\u0445. \u041c\u0438\u043d\u0438\u043c\u0430\u043b\u044c\u043d\u044b\u0439 overlap \u0432 \u044d\u0442\u043e\u043c \u0446\u0438\u043a\u043b\u0435 \u2013 1, \u0437\u043d\u0430\u0447\u0438\u0442, \u043d\u0430\u043c \u043f\u043e\u0434\u043e\u0439\u0434\u0451\u0442 \u043b\u044e\u0431\u0430\u044f \u0438\u0437 \u043f\u043e\u0441\u043b\u0435\u0434\u043e\u0432\u0430\u0442\u0435\u043b\u044c\u043d\u043e\u0441\u0442\u0435\u0439 {0, 2, 1} (cde ++ eab ++ abc = cdeabc) \u0438\u043b\u0438 {2, 1, 0} (eab ++ abc ++ cde = aebcde).<br \/>  \u0414\u0430\u043b\u0435\u0435 \u043f\u0440\u0438\u0432\u0435\u0434\u0451\u043d \u043a\u043e\u0434, \u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u0446\u0438\u043a\u043b\u0438\u0447\u0435\u0441\u043a\u0438 \u0441\u0434\u0432\u0438\u0433\u0430\u0435\u0442 \u043a\u0430\u0436\u0434\u044b\u0439 \u0446\u0438\u043a\u043b \u0432 \u043f\u043e\u043a\u0440\u044b\u0442\u0438\u0438 \u0442\u0430\u043a, \u0447\u0442\u043e\u0431\u044b \u043c\u0438\u043d\u0438\u043c\u0438\u0437\u0438\u0440\u043e\u0432\u0430\u0442\u044c overlap\u2019\u044b \u043f\u0435\u0440\u0432\u044b\u0445 \u0438 \u043f\u043e\u0441\u043b\u0435\u0434\u043d\u0438\u0445 \u0441\u0442\u0440\u043e\u043a \u043a\u0430\u0436\u0434\u043e\u0433\u043e \u0446\u0438\u043a\u043b\u0430, \u0438 \u043a\u043e\u043d\u0441\u0442\u0440\u0443\u0438\u0440\u0443\u0435\u0442 \u043d\u0430\u0434\u0441\u0442\u0440\u043e\u043a\u0438 \u0434\u043b\u044f \u043a\u0430\u0436\u0434\u043e\u0433\u043e \u0446\u0438\u043a\u043b\u0430.<\/p>\n<pre><code class=\"java\">         \/\/ \u0426\u0438\u043a\u043b\u0438\u0447\u0435\u0441\u043a\u0438\u0439 \u0441\u0434\u0432\u0438\u0433 \u043a\u0430\u0436\u0434\u043e\u0433\u043e \u0446\u0438\u043a\u043b\u0430 \u0432 \u043f\u043e\u043a\u0440\u044b\u0442\u0438\u0438 \u0442\u0430\u043a\u043e\u0439, \u0447\u0442\u043e\u0431\u044b          \/\/ \u043c\u0438\u043d\u0438\u043c\u0438\u0437\u0438\u0440\u043e\u0432\u0430\u0442\u044c overlap \u043f\u0435\u0440\u0432\u043e\u0439 \u0438 \u043f\u043e\u0441\u043b\u0435\u0434\u043d\u0435\u0439 \u0441\u0442\u0440\u043e\u043a\u0438 \u0432 \u0446\u0438\u043a\u043b\u0435          \/\/ \u0438 \u043a\u043e\u043d\u0441\u0442\u0440\u0443\u0438\u0440\u043e\u0432\u0430\u043d\u0438\u0435 \u043d\u0430\u0434\u0441\u0442\u0440\u043e\u043a\u0438 \u0434\u043b\u044f \u043a\u0430\u0436\u0434\u043e\u0433\u043e \u0446\u0438\u043a\u043b\u0430.          ArrayList&lt;String&gt; superstrings = new ArrayList&lt;String&gt;();          for (ArrayList&lt;Integer&gt; c : cycles)          {             String str = &quot;&quot;;             ArrayList&lt;Integer&gt; ovs = new ArrayList&lt;Integer&gt;();                        for (int i = 0; i &lt; c.size() - 1; i++)                ovs.add(overlaps[c.get(i)][c.get(i+1)]);                        int min = overlaps[c.get(c.size()-1)][c.get(0)];             int shift = 0;                        for (int i = 0; i &lt; ovs.size(); i++)             if (ovs.get(i) &lt; min)              {                min = ovs.get(i);                shift = i + 1;             }                        Collections.rotate(c, -shift);                        for (int i = 0; i &lt; c.size() - 1; i++)                str += prefix(strings.get(c.get(i)),                            overlaps[c.get(i)][c.get(i+1)]);                str += strings.get(c.get(c.size()-1));             superstrings.add(str);          } <\/code><\/pre>\n<p>  \u0422\u0435\u043f\u0435\u0440\u044c \u0443 \u043d\u0430\u0441 \u0435\u0441\u0442\u044c \u043a\u0440\u0430\u0442\u0447\u0430\u0439\u0448\u0438\u0435 \u043d\u0430\u0434\u0441\u0442\u0440\u043e\u043a\u0438 \u0434\u043b\u044f \u043a\u0430\u0436\u0434\u043e\u0433\u043e \u0446\u0438\u043a\u043b\u0430 \u0432 \u043f\u043e\u043a\u0440\u044b\u0442\u0438\u0438. \u0420\u0430\u0441\u0441\u043c\u0430\u0442\u0440\u0438\u0432\u0430\u0435\u043c\u044b\u0439 \u0430\u043b\u0433\u043e\u0440\u0438\u0442\u043c \u0441 \u043c\u043d\u043e\u0436\u0438\u0442\u0435\u043b\u0435\u043c 4 \u043f\u0440\u0435\u0434\u043f\u043e\u043b\u0430\u0433\u0430\u0435\u0442 \u043f\u0440\u043e\u0441\u0442\u0443\u044e \u043a\u043e\u043d\u043a\u0430\u0442\u0435\u043d\u0430\u0446\u0438\u044e \u044d\u0442\u0438\u0445 \u0441\u0442\u0440\u043e\u043a.<\/p>\n<pre><code class=\"java\">         \/\/ \u041a\u043e\u043d\u043a\u0430\u0442\u0435\u043d\u0430\u0446\u0438\u044f \u0432\u0441\u0435\u0445 \u043d\u0430\u0434\u0441\u0442\u0440\u043e\u043a \u0438\u0437 superstrings          StringBuilder superstring = new StringBuilder();          for (String str : superstrings)             superstring.append(str);                   return superstring.toString(); <\/code><\/pre>\n<h2>\u0418\u0441\u0445\u043e\u0434\u043d\u044b\u0435 \u043a\u043e\u0434\u044b \u0438 \u0442\u0435\u0441\u0442\u0438\u0440\u043e\u0432\u0430\u043d\u0438\u0435<\/h2>\n<p>  \u0418\u0441\u0445\u043e\u0434\u043d\u044b\u0435 \u043a\u043e\u0434\u044b \u0436\u0430\u0434\u043d\u043e\u0433\u043e (Greedy.java) \u0438 \u0411\u043b\u044e\u043c\u0430-\u042f\u043d\u0433\u0430-\u041b\u0438-\u0422\u0440\u043e\u043c\u043f\u0430-\u042f\u043d\u043d\u0430\u043a\u0430\u043a\u0438\u0441\u0430 (Assign.java) \u0430\u043b\u0433\u043e\u0440\u0438\u0442\u043c\u043e\u0432 \u0434\u043e\u0441\u0442\u0443\u043f\u043d\u044b \u0432 git-\u0440\u0435\u043f\u043e\u0437\u0438\u0442\u043e\u0440\u0438\u0438 \u043f\u043e \u0441\u0441\u044b\u043b\u043a\u0435 <a href=\"https:\/\/bitbucket.org\/andkorsh\/scss\/src\">bitbucket.org\/andkorsh\/scss\/src<\/a>. \u0422\u0430\u043a\u0436\u0435 \u0442\u0430\u043c \u0435\u0441\u0442\u044c \u0438\u0441\u043f\u043e\u043b\u043d\u044f\u0435\u043c\u044b\u0439 \u043a\u043b\u0430\u0441\u0441 Main.java, \u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u043f\u0440\u0438 \u0437\u0430\u043f\u0443\u0441\u043a\u0435 \u0437\u0430\u043f\u0440\u0430\u0448\u0438\u0432\u0430\u0435\u0442 \u043a\u043e\u043b\u0438\u0447\u0435\u0441\u0442\u0432\u043e \u0437\u0430\u043f\u0443\u0441\u043a\u043e\u0432 \u0434\u043b\u044f \u0437\u0430\u043c\u0435\u0440\u0430 \u0441\u043a\u043e\u0440\u043e\u0441\u0442\u0438 \u0430\u043b\u0433\u043e\u0440\u0438\u0442\u043c\u043e\u0432 \u0438 \u043f\u0443\u0442\u044c \u043a \u0432\u0445\u043e\u0434\u043d\u043e\u043c\u0443 \u0444\u0430\u0439\u043b\u0443. \u0422\u0430\u043a\u0436\u0435 \u043a\u043b\u0430\u0441\u0441 Main \u0443\u043c\u0435\u0435\u0442 \u0433\u0435\u043d\u0435\u0440\u0438\u0440\u043e\u0432\u0430\u0442\u044c \u0432\u0445\u043e\u0434\u043d\u044b\u0435 \u0434\u0430\u043d\u043d\u044b\u0435 \u0441\u0430\u043c, \u0434\u043b\u044f \u044d\u0442\u043e\u0433\u043e \u0432\u043c\u0435\u0441\u0442\u043e \u0438\u043c\u0435\u043d\u0438 \u0444\u0430\u0439\u043b\u0430 \u043d\u0443\u0436\u043d\u043e \u0432\u0432\u0435\u0441\u0442\u0438 \u00abrandom\u00bb, \u043f\u043e\u0441\u043b\u0435 \u0447\u0435\u0433\u043e \u0431\u0443\u0434\u0435\u0442 \u0437\u0430\u043f\u0440\u043e\u0448\u0435\u043d\u043e \u043a\u043e\u043b\u0438\u0447\u0435\u0441\u0442\u0432\u043e \u0441\u0442\u0440\u043e\u043a, \u043c\u0430\u043a\u0441\u0438\u043c\u0430\u043b\u044c\u043d\u0430\u044f \u0434\u043b\u0438\u043d\u0430 \u0441\u0442\u0440\u043e\u043a\u0438, \u0444\u0438\u043a\u0441\u0438\u0440\u043e\u0432\u0430\u043d\u043d\u0430\u044f \u0434\u043b\u0438\u043d\u0430 \u0438\u043b\u0438 \u043d\u0435\u0442 \u0438 \u043a\u043e\u043b\u0438\u0447\u0435\u0441\u0442\u0432\u043e \u0441\u0438\u043c\u0432\u043e\u043b\u043e\u0432 \u0432 \u0430\u043b\u0444\u0430\u0432\u0438\u0442\u0435. \u041e\u0442\u0447\u0451\u0442 \u0437\u0430\u043f\u0438\u0448\u0435\u0442\u0441\u044f \u0432 \u0444\u0430\u0439\u043b output.txt.<\/p>\n<p>  \u0418\u0441\u0445\u043e\u0434\u043d\u044b\u0435 \u043a\u043e\u0434\u044b \u0433\u0430\u0440\u0430\u043d\u0442\u0438\u0440\u043e\u0432\u0430\u043d\u043d\u043e \u043a\u043e\u043c\u043f\u0438\u043b\u0438\u0440\u0443\u044e\u0442\u0441\u044f javac, \u043d\u0430\u0447\u0438\u043d\u0430\u044f \u0441 \u0432\u0435\u0440\u0441\u0438\u0438 \u201c1.6.0_05\u201d.<\/p>\n<p>  \u0422\u0435\u0441\u0442\u0438\u0440\u043e\u0432\u0430\u043d\u0438\u0435 \u0432\u044b\u043f\u043e\u043b\u043d\u044f\u0435\u0442\u0441\u044f \u0441 \u043f\u043e\u043c\u043e\u0449\u044c\u044e \u0444\u0443\u043d\u043a\u0446\u0438\u0438 test \u043a\u043b\u0430\u0441\u0441\u0430 Main.<\/p>\n<pre><code class=\"java\">      private static int test(ArrayList&lt;String&gt; substrings, String superstring)       {          int errors = 0;                    for (String substring : substrings)             if (superstring.indexOf(substring) &lt; 0)                errors++;            return errors;       } <\/code><\/pre>\n<h2>\u0418\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u043d\u043d\u0430\u044f \u043b\u0438\u0442\u0435\u0440\u0430\u0442\u0443\u0440\u0430<\/h2>\n<p>  <b>[1]<\/b>: \u0414\u044d\u043d \u0413\u0430\u0441\u0444\u0438\u043b\u0434. \u0421\u0442\u0440\u043e\u043a\u0438, \u0434\u0435\u0440\u0435\u0432\u044c\u044f \u0438 \u043f\u043e\u0441\u043b\u0435\u0434\u043e\u0432\u0430\u0442\u0435\u043b\u044c\u043d\u043e\u0441\u0442\u0438 \u0432 \u0430\u043b\u0433\u043e\u0440\u0438\u0442\u043c\u0430\u0445. \u0418\u043d\u0444\u043e\u0440\u043c\u0430\u0442\u0438\u043a\u0430 \u0438 \u0432\u044b\u0447\u0438\u0441\u043b\u0438\u0442\u0435\u043b\u044c\u043d\u0430\u044f \u0431\u0438\u043e\u043b\u043e\u0433\u0438\u044f. \u041d\u0435\u0432\u0441\u043a\u0438\u0439 \u0414\u0438\u0430\u043b\u0435\u043a\u0442, \u0411\u0425\u0412-\u041f\u0435\u0442\u0435\u0440\u0431\u0443\u0440\u0433, 2003\u0433. \u2013 656 \u0441.: ISBN 5-7940-0103-8, 5-94157-321-9, 0-521-58519-8.<br \/>  <a href=\"http:\/\/www.ozon.ru\/context\/detail\/id\/1393109\/\">www.ozon.ru\/context\/detail\/id\/1393109\/<\/a><\/p>\n<p>  <b>[2]<\/b>: Dan Gusfield. Algorithms on Strings, Trees and Sequences: Computer Science and Computational Biology. THE PRESS SYNDICATE OF THE UNIVERSITY OF CAMBRIDGE, 1997\u0433. \u2013 534 \u0441.: ISBN-10: 0521585198, ISBN-13: 978-0521585194.<br \/>  <a href=\"http:\/\/www.amazon.com\/Algorithms-Strings-Trees-Sequences-Computational\/dp\/0521585198\">www.amazon.com\/Algorithms-Strings-Trees-Sequences-Computational\/dp\/0521585198<\/a><\/p>\n<p>  <b>[3]<\/b>: Shunji Li, Wenzheng Chi. Lecture #3: Shortest Common Superstring \u2013 CS 352 (Advanced Algorithms), Spring 2011. <br \/>  <a href=\"http:\/\/cs.carleton.edu\/faculty\/dlibenno\/old\/cs352-spring11\/L03-shortest-superstring.pdf\">cs.carleton.edu\/faculty\/dlibenno\/old\/cs352-spring11\/L03-shortest-superstring.pdf<\/a> \t\t\t<\/p>\n<div class=\"clear\"><\/div>\n<\/p><\/div>\n<p> \u0441\u0441\u044b\u043b\u043a\u0430 \u043d\u0430 \u043e\u0440\u0438\u0433\u0438\u043d\u0430\u043b \u0441\u0442\u0430\u0442\u044c\u0438 <a href=\"http:\/\/habrahabr.ru\/post\/201656\/\"> http:\/\/habrahabr.ru\/post\/201656\/<\/a><\/p>\n","protected":false},"excerpt":{"rendered":"<div class=\"content html_format\"> \t\t\t<b>\u041f\u0440\u043e\u0431\u043b\u0435\u043c\u0430 \u043a\u0440\u0430\u0442\u0447\u0430\u0439\u0448\u0435\u0439 \u043e\u0431\u0449\u0435\u0439 \u043d\u0430\u0434\u0441\u0442\u0440\u043e\u043a\u0438<\/b> \u0444\u043e\u0440\u043c\u0443\u043b\u0438\u0440\u0443\u0435\u0442\u0441\u044f \u0441\u043b\u0435\u0434\u0443\u044e\u0449\u0438\u043c \u043e\u0431\u0440\u0430\u0437\u043e\u043c: \u043d\u0430\u0439\u0442\u0438 \u043a\u0440\u0430\u0442\u0447\u0430\u0439\u0448\u0443\u044e \u0441\u0442\u0440\u043e\u043a\u0443, \u0442\u0430\u043a\u0443\u044e, \u0447\u0442\u043e \u043a\u0430\u0436\u0434\u0430\u044f \u0441\u0442\u0440\u043e\u043a\u0430 \u0438\u0437 \u0437\u0430\u0434\u0430\u043d\u043d\u043e\u0433\u043e \u043d\u0430\u0431\u043e\u0440\u0430 \u044f\u0432\u043b\u044f\u043b\u0430\u0441\u044c \u0431\u044b \u0435\u0451 \u043f\u043e\u0434\u0441\u0442\u0440\u043e\u043a\u043e\u0439. \u042d\u0442\u0430 \u043f\u0440\u043e\u0431\u043b\u0435\u043c\u0430 \u0438\u043c\u0435\u0435\u0442 \u043c\u0435\u0441\u0442\u043e \u043a\u0430\u043a \u0432 \u0431\u0438\u043e\u0438\u043d\u0444\u043e\u0440\u043c\u0430\u0442\u0438\u043a\u0435 (\u0437\u0430\u0434\u0430\u0447\u0430 \u0441\u0431\u043e\u0440\u043a\u0438 \u0433\u0435\u043d\u043e\u043c\u0430 \u0432 \u043e\u0431\u0449\u0435\u043c \u0441\u043b\u0443\u0447\u0430\u0435) \u0442\u0430\u043a \u0438 \u0432 \u0441\u0436\u0430\u0442\u0438\u0438 \u0434\u0430\u043d\u043d\u044b\u0445 (\u0432\u043c\u0435\u0441\u0442\u043e \u0434\u0430\u043d\u043d\u044b\u0445 \u0445\u0440\u0430\u043d\u0438\u0442\u044c \u0438\u0445 \u043d\u0430\u0434\u0441\u0442\u0440\u043e\u043a\u0443 \u0438 \u043f\u043e\u0441\u043b\u0435\u0434\u043e\u0432\u0430\u0442\u0435\u043b\u044c\u043d\u043e\u0441\u0442\u044c \u043f\u0430\u0440, \u0432\u0438\u0434\u0430 (\u0438\u043d\u0434\u0435\u043a\u0441 \u0432\u0445\u043e\u0436\u0434\u0435\u043d\u0438\u044f, \u0434\u043b\u0438\u043d\u0430)). <\/p>\n<p>  \u041a\u043e\u0433\u0434\u0430 \u044f \u0438\u0441\u043a\u0430\u043b \u0432 \u0441\u0435\u0442\u0438 \u0438\u043d\u0444\u043e\u0440\u043c\u0430\u0446\u0438\u044e \u043f\u043e \u044d\u0442\u043e\u0439 \u043f\u0440\u043e\u0431\u043b\u0435\u043c\u0435 \u0438 \u0435\u0451 \u0440\u0435\u0448\u0435\u043d\u0438\u044e \u043d\u0430 \u0440\u0443\u0441\u0441\u043a\u043e\u043c \u044f\u0437\u044b\u043a\u0435 \u2014 \u043d\u0430\u0445\u043e\u0434\u0438\u043b\u0430\u0441\u044c \u043b\u0438\u0448\u044c \u043f\u0430\u0440\u0430 \u043f\u043e\u0441\u0442\u043e\u0432 \u043f\u0440\u043e \u0431\u0438\u043e\u0438\u043d\u0444\u043e\u0440\u043c\u0430\u0442\u0438\u043a\u0435, \u0433\u0434\u0435 \u0432\u0441\u043a\u043e\u043b\u044c\u0437\u044c \u0443\u043f\u043e\u043c\u0438\u043d\u0430\u044e\u0442\u0441\u044f \u044d\u0442\u0438 \u0441\u043b\u043e\u0432\u0430. \u041a\u043e\u0434\u0430 (\u043a\u0440\u043e\u043c\u0435 \u0436\u0430\u0434\u043d\u043e\u0433\u043e \u0430\u043b\u0433\u043e\u0440\u0438\u0442\u043c\u0430), \u043a\u043e\u043d\u0435\u0447\u043d\u043e \u0436\u0435, \u0442\u043e\u0436\u0435 \u043d\u0435 \u0431\u044b\u043b\u043e. \u0420\u0430\u0437\u043e\u0431\u0440\u0430\u0432\u0448\u0438\u0441\u044c \u0432 \u043f\u0440\u043e\u0431\u043b\u0435\u043c\u0435, \u044d\u0442\u043e\u0442 \u0444\u0430\u043a\u0442 \u0441\u043f\u043e\u0434\u0432\u0438\u0433 \u043d\u0430 \u0441\u0442\u0430\u0442\u044c\u044e \u0437\u0434\u0435\u0441\u044c.<\/p>\n<p>  \u041e\u0441\u0442\u043e\u0440\u043e\u0436\u043d\u043e, 4 \u043c\u0435\u0433\u0430\u0431\u0430\u0439\u0442\u0430!  <\/p>\n","protected":false},"author":1,"featured_media":0,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[],"tags":[],"class_list":["post-201656","post","type-post","status-publish","format-standard","hentry"],"_links":{"self":[{"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=\/wp\/v2\/posts\/201656","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=%2Fwp%2Fv2%2Fcomments&post=201656"}],"version-history":[{"count":0,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=\/wp\/v2\/posts\/201656\/revisions"}],"wp:attachment":[{"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=%2Fwp%2Fv2%2Fmedia&parent=201656"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=%2Fwp%2Fv2%2Fcategories&post=201656"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=%2Fwp%2Fv2%2Ftags&post=201656"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}