<?xml version="1.0"?>
<feed xmlns="http://www.w3.org/2005/Atom" xml:lang="ru">
		<id>http://neerc.ifmo.ru/wiki/api.php?action=feedcontributions&amp;feedformat=atom&amp;user=91.108.28.38&amp;*</id>
		<title>Викиконспекты - Вклад участника [ru]</title>
		<link rel="self" type="application/atom+xml" href="http://neerc.ifmo.ru/wiki/api.php?action=feedcontributions&amp;feedformat=atom&amp;user=91.108.28.38&amp;*"/>
		<link rel="alternate" type="text/html" href="http://neerc.ifmo.ru/wiki/index.php?title=%D0%A1%D0%BB%D1%83%D0%B6%D0%B5%D0%B1%D0%BD%D0%B0%D1%8F:%D0%92%D0%BA%D0%BB%D0%B0%D0%B4/91.108.28.38"/>
		<updated>2026-05-05T08:58:18Z</updated>
		<subtitle>Вклад участника</subtitle>
		<generator>MediaWiki 1.30.0</generator>

	<entry>
		<id>http://neerc.ifmo.ru/wiki/index.php?title=Level_Ancestor_problem&amp;diff=71146</id>
		<title>Level Ancestor problem</title>
		<link rel="alternate" type="text/html" href="http://neerc.ifmo.ru/wiki/index.php?title=Level_Ancestor_problem&amp;diff=71146"/>
				<updated>2019-05-06T19:39:36Z</updated>
		
		<summary type="html">&lt;p&gt;91.108.28.38: &lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;'''Задача о уровне предка''' (англ. &amp;quot;Level Ancestor problem&amp;quot;) является задачей о превращении данного корневого дерева T в структуру данных, которая сможет определить предка любого узла на заданном расстоянии от корня дерева.&lt;br /&gt;
{{Задача&lt;br /&gt;
|definition = Дано корневое дерево &amp;lt;tex&amp;gt;T&amp;lt;/tex&amp;gt; c &amp;lt;tex&amp;gt;n&amp;lt;/tex&amp;gt; вершинами. Поступают запросы вида &amp;lt;tex&amp;gt;(v, k)&amp;lt;/tex&amp;gt;, для каждого из которых необходимо найти предка вершины &amp;lt;tex&amp;gt;v&amp;lt;/tex&amp;gt;, который находится на расстоянии &amp;lt;tex&amp;gt;k&amp;lt;/tex&amp;gt; от корня дерева &amp;lt;tex&amp;gt;T&amp;lt;/tex&amp;gt;. &lt;br /&gt;
}}&lt;br /&gt;
== Наивная реализация ==&lt;br /&gt;
Используя обход в глубину посчитаем глубину каждой вершины дерева (это можно сделать за &amp;lt;tex&amp;gt;O(n)&amp;lt;/tex&amp;gt;), после чего можем из вершины &amp;lt;tex&amp;gt;v&amp;lt;/tex&amp;gt; подняться до необходимой глубины вершины &amp;lt;tex&amp;gt;k&amp;lt;/tex&amp;gt;, что так же в худшем случае работает за &amp;lt;tex&amp;gt;O(n)&amp;lt;/tex&amp;gt;. Получили алгоритм за &amp;lt;tex&amp;gt;&amp;lt;O(n),O(n)&amp;gt;&amp;lt;/tex&amp;gt;, где время ответа на запрос можно улучшить до &amp;lt;tex&amp;gt;O(\log n)&amp;lt;/tex&amp;gt; c помощью [[Метод двоичного подъёма | предподсчета двоичных подъемов]], но тогда и время предподсчета в наивной реализации (посчитать подъемы для всех вершин) ухудшится до &amp;lt;tex&amp;gt;&amp;lt;O(n \log n),O(\log n)&amp;gt;&amp;lt;/tex&amp;gt;.&lt;br /&gt;
== Лестничный алгоритм ==&lt;br /&gt;
Этот алгоритм базируется на различных способах [[Heavy-light декомпозиция | декомпозиции дерева]] (выберем heavy-light декомпозицию), из свойств этого разбиения следует, что подняться на любую высоту из вершины &amp;lt;tex&amp;gt;v&amp;lt;/tex&amp;gt; мы можем за &amp;lt;tex&amp;gt;O(\log n)&amp;lt;/tex&amp;gt;. Данное разбиение можно строить за &amp;lt;tex&amp;gt;O(n)&amp;lt;/tex&amp;gt;, что дает нам алгоритм за &amp;lt;tex&amp;gt;&amp;lt;O(n), O(\log n)&amp;gt;&amp;lt;/tex&amp;gt;.&lt;br /&gt;
== Алгоритм за &amp;lt;tex&amp;gt;&amp;lt;O(n), O(1)&amp;gt;&amp;lt;/tex&amp;gt; ==&lt;/div&gt;</summary>
		<author><name>91.108.28.38</name></author>	</entry>

	<entry>
		<id>http://neerc.ifmo.ru/wiki/index.php?title=Level_Ancestor_problem&amp;diff=71145</id>
		<title>Level Ancestor problem</title>
		<link rel="alternate" type="text/html" href="http://neerc.ifmo.ru/wiki/index.php?title=Level_Ancestor_problem&amp;diff=71145"/>
				<updated>2019-05-06T19:30:54Z</updated>
		
		<summary type="html">&lt;p&gt;91.108.28.38: &lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;'''Задача о уровне предка''' (англ. &amp;quot;Level Ancestor problem&amp;quot;) является задачей о превращении данного корневого дерева T в структуру данных, которая сможет определить предка любого узла на заданном расстоянии от корня дерева.&lt;br /&gt;
{{Задача&lt;br /&gt;
|definition = Дано корневое дерево &amp;lt;tex&amp;gt;T&amp;lt;/tex&amp;gt; c &amp;lt;tex&amp;gt;n&amp;lt;/tex&amp;gt; вершинами. Поступают запросы вида &amp;lt;tex&amp;gt;(v, k)&amp;lt;/tex&amp;gt;, для каждого из которых необходимо найти предка вершины &amp;lt;tex&amp;gt;v&amp;lt;/tex&amp;gt;, который находится на расстоянии &amp;lt;tex&amp;gt;k&amp;lt;/tex&amp;gt; от корня дерева &amp;lt;tex&amp;gt;T&amp;lt;/tex&amp;gt;. &lt;br /&gt;
}}&lt;br /&gt;
== Наивная реализация ==&lt;br /&gt;
Используя обход в глубину посчитаем глубину каждой вершины дерева (это можно сделать за &amp;lt;tex&amp;gt;O(n)&amp;lt;/tex&amp;gt;), после чего можем из вершины &amp;lt;tex&amp;gt;v&amp;lt;/tex&amp;gt; подняться до необходимой глубины вершины &amp;lt;tex&amp;gt;k&amp;lt;/tex&amp;gt;, что так же в худшем случае работает за &amp;lt;tex&amp;gt;O(n)&amp;lt;/tex&amp;gt;. Получили алгоритм за &amp;lt;tex&amp;gt;&amp;lt;O(n),O(n)&amp;gt;&amp;lt;/tex&amp;gt;, где время ответа на запрос можно улучшить до &amp;lt;tex&amp;gt;O(\log n)&amp;lt;/tex&amp;gt; c помощью [[Метод двоичного подъёма | предподсчета двоичных подъемов]], но тогда и время предподсчета в наивной реализации (посчитать подъемы для всех вершин) ухудшится до &amp;lt;tex&amp;gt;&amp;lt;O(n \log n),O(\log n)&amp;gt;&amp;lt;/tex&amp;gt;.&lt;br /&gt;
== Лестничный алгоритм ==&lt;br /&gt;
Этот алгоритм базируется на различных способах [[Heavy-light декомпозиция | декомпозиции дерева]](выберем heavy-light декомпозицию), из свойств этого разбиения следует, что подняться на любую высоту из вершины &amp;lt;tex&amp;gt;v&amp;lt;/tex&amp;gt; мы можем за &amp;lt;tex&amp;gt;O(\log n)&amp;lt;/tex&amp;gt;. Данное разбиение можно строить за &amp;lt;tex&amp;gt;O(n)&amp;lt;/tex&amp;gt;, что дает нам алгоритм за &amp;lt;tex&amp;gt;&amp;lt;O(n), O(\log n)&amp;gt;&amp;lt;/tex&amp;gt;.&lt;/div&gt;</summary>
		<author><name>91.108.28.38</name></author>	</entry>

	<entry>
		<id>http://neerc.ifmo.ru/wiki/index.php?title=Level_Ancestor_problem&amp;diff=71144</id>
		<title>Level Ancestor problem</title>
		<link rel="alternate" type="text/html" href="http://neerc.ifmo.ru/wiki/index.php?title=Level_Ancestor_problem&amp;diff=71144"/>
				<updated>2019-05-06T18:55:43Z</updated>
		
		<summary type="html">&lt;p&gt;91.108.28.38: &lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;'''Задача о уровне предка''' (англ. &amp;quot;Level Ancestor problem&amp;quot;) является задачей о превращении данного корневого дерева T в структуру данных, которая сможет определить предка любого узла на заданном расстоянии от корня дерева.&lt;br /&gt;
{{Задача&lt;br /&gt;
|definition = Дано корневое дерево &amp;lt;tex&amp;gt;T&amp;lt;/tex&amp;gt; c &amp;lt;tex&amp;gt;n&amp;lt;/tex&amp;gt; вершинами. Поступают запросы вида &amp;lt;tex&amp;gt;(v, k)&amp;lt;/tex&amp;gt;, для каждого из которых необходимо найти предка вершины &amp;lt;tex&amp;gt;v&amp;lt;/tex&amp;gt;, который находится на расстоянии &amp;lt;tex&amp;gt;k&amp;lt;/tex&amp;gt; от корня дерева &amp;lt;tex&amp;gt;T&amp;lt;/tex&amp;gt;. &lt;br /&gt;
}}&lt;br /&gt;
== Наивная реализация ==&lt;br /&gt;
Используя обход в глубину посчитаем глубину каждой вершины дерева (это можно сделать за &amp;lt;tex&amp;gt;O(n)&amp;lt;/tex&amp;gt;), после чего можем из вершины &amp;lt;tex&amp;gt;v&amp;lt;/tex&amp;gt; подняться до необходимой глубины вершины &amp;lt;tex&amp;gt;k&amp;lt;/tex&amp;gt;, что так же в худшем случае работает за &amp;lt;tex&amp;gt;O(n)&amp;lt;/tex&amp;gt;. Получили алгоритм за &amp;lt;tex&amp;gt;&amp;lt;O(n),O(n)&amp;gt;&amp;lt;/tex&amp;gt;, где время ответа на запрос можно улучшить до &amp;lt;tex&amp;gt;O(\log n)&amp;lt;/tex&amp;gt; c помощью предподсчета двоичных подъемов, но тогда и время предподсчета в наивной реализации (посчитать подъемы для всех вершин) ухудшится до &amp;lt;tex&amp;gt;&amp;lt;O(n \log n),O(\log n)&amp;gt;&amp;lt;/tex&amp;gt;.&lt;br /&gt;
== Лестничный алгоритм ==&lt;/div&gt;</summary>
		<author><name>91.108.28.38</name></author>	</entry>

	<entry>
		<id>http://neerc.ifmo.ru/wiki/index.php?title=Level_Ancestor_problem&amp;diff=71143</id>
		<title>Level Ancestor problem</title>
		<link rel="alternate" type="text/html" href="http://neerc.ifmo.ru/wiki/index.php?title=Level_Ancestor_problem&amp;diff=71143"/>
				<updated>2019-05-06T18:54:17Z</updated>
		
		<summary type="html">&lt;p&gt;91.108.28.38: &lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;'''Задача о уровне предка''' - (англ. &amp;quot;Level Ancestor problem&amp;quot;) является задачей о превращении данного корневого дерева T в структуру данных, которая сможет определить предка любого узла на заданном расстоянии от корня дерева.&lt;br /&gt;
{{Задача&lt;br /&gt;
|definition = Дано корневое дерево &amp;lt;tex&amp;gt;T&amp;lt;/tex&amp;gt; c &amp;lt;tex&amp;gt;n&amp;lt;/tex&amp;gt; вершинами. Поступают запросы вида &amp;lt;tex&amp;gt;(v, k)&amp;lt;/tex&amp;gt;, для каждого из которых необходимо найти предка вершины &amp;lt;tex&amp;gt;v&amp;lt;/tex&amp;gt;, который находится на расстоянии &amp;lt;tex&amp;gt;k&amp;lt;/tex&amp;gt; от корня дерева &amp;lt;tex&amp;gt;T&amp;lt;/tex&amp;gt;. &lt;br /&gt;
}}&lt;br /&gt;
== Наивная реализация ==&lt;br /&gt;
Используя обход в глубину посчитаем глубину каждой вершины дерева (это можно сделать за &amp;lt;tex&amp;gt;O(n)&amp;lt;/tex&amp;gt;), после чего можем из вершины &amp;lt;tex&amp;gt;v&amp;lt;/tex&amp;gt; подняться до необходимой глубины вершины &amp;lt;tex&amp;gt;k&amp;lt;/tex&amp;gt;, что так же в худшем случае работает за &amp;lt;tex&amp;gt;O(n)&amp;lt;/tex&amp;gt;. Получили алгоритм за &amp;lt;tex&amp;gt;&amp;lt;O(n),O(n)&amp;gt;&amp;lt;/tex&amp;gt;, где время ответа на запрос можно улучшить до &amp;lt;tex&amp;gt;O(\log n)&amp;lt;/tex&amp;gt; c помощью предподсчета двоичных подъемов, но тогда и время предподсчета в наивной реализации (посчитать подъемы для всех) ухудшится до &amp;lt;tex&amp;gt;&amp;lt;O(n \log n),O(\log n)&amp;gt;&amp;lt;/tex&amp;gt;.&lt;br /&gt;
== Лестничный алгоритм ==&lt;/div&gt;</summary>
		<author><name>91.108.28.38</name></author>	</entry>

	</feed>