<?xml version="1.0"?>
<feed xmlns="http://www.w3.org/2005/Atom" xml:lang="en">
	<id>http://sfsys.ru/index.php?action=history&amp;feed=atom&amp;title=Template%3A%D0%9F%D1%80%D0%B8%D0%BC%D0%B5%D1%80_%D0%BF%D0%BE%D0%B8%D1%81%D0%BA%D0%B0_%D0%B2_%D1%81%D0%BE%D1%80%D1%82%D0%B8%D1%80%D0%BE%D0%B2%D0%B0%D0%BD%D0%BD%D1%8B%D1%85_%D1%82%D0%B0%D0%B1%D0%BB%D0%B8%D1%86%D0%B0%D1%85</id>
	<title>Template:Пример поиска в сортированных таблицах - Revision history</title>
	<link rel="self" type="application/atom+xml" href="http://sfsys.ru/index.php?action=history&amp;feed=atom&amp;title=Template%3A%D0%9F%D1%80%D0%B8%D0%BC%D0%B5%D1%80_%D0%BF%D0%BE%D0%B8%D1%81%D0%BA%D0%B0_%D0%B2_%D1%81%D0%BE%D1%80%D1%82%D0%B8%D1%80%D0%BE%D0%B2%D0%B0%D0%BD%D0%BD%D1%8B%D1%85_%D1%82%D0%B0%D0%B1%D0%BB%D0%B8%D1%86%D0%B0%D1%85"/>
	<link rel="alternate" type="text/html" href="http://sfsys.ru/index.php?title=Template:%D0%9F%D1%80%D0%B8%D0%BC%D0%B5%D1%80_%D0%BF%D0%BE%D0%B8%D1%81%D0%BA%D0%B0_%D0%B2_%D1%81%D0%BE%D1%80%D1%82%D0%B8%D1%80%D0%BE%D0%B2%D0%B0%D0%BD%D0%BD%D1%8B%D1%85_%D1%82%D0%B0%D0%B1%D0%BB%D0%B8%D1%86%D0%B0%D1%85&amp;action=history"/>
	<updated>2026-04-04T12:04:52Z</updated>
	<subtitle>Revision history for this page on the wiki</subtitle>
	<generator>MediaWiki 1.31.1</generator>
	<entry>
		<id>http://sfsys.ru/index.php?title=Template:%D0%9F%D1%80%D0%B8%D0%BC%D0%B5%D1%80_%D0%BF%D0%BE%D0%B8%D1%81%D0%BA%D0%B0_%D0%B2_%D1%81%D0%BE%D1%80%D1%82%D0%B8%D1%80%D0%BE%D0%B2%D0%B0%D0%BD%D0%BD%D1%8B%D1%85_%D1%82%D0%B0%D0%B1%D0%BB%D0%B8%D1%86%D0%B0%D1%85&amp;diff=3728&amp;oldid=prev</id>
		<title>Admin: 1 revision imported</title>
		<link rel="alternate" type="text/html" href="http://sfsys.ru/index.php?title=Template:%D0%9F%D1%80%D0%B8%D0%BC%D0%B5%D1%80_%D0%BF%D0%BE%D0%B8%D1%81%D0%BA%D0%B0_%D0%B2_%D1%81%D0%BE%D1%80%D1%82%D0%B8%D1%80%D0%BE%D0%B2%D0%B0%D0%BD%D0%BD%D1%8B%D1%85_%D1%82%D0%B0%D0%B1%D0%BB%D0%B8%D1%86%D0%B0%D1%85&amp;diff=3728&amp;oldid=prev"/>
		<updated>2021-02-07T06:56:29Z</updated>

		<summary type="html">&lt;p&gt;1 revision imported&lt;/p&gt;
&lt;table class=&quot;diff diff-contentalign-left&quot; data-mw=&quot;interface&quot;&gt;
				&lt;tr class=&quot;diff-title&quot; lang=&quot;en&quot;&gt;
				&lt;td colspan=&quot;1&quot; style=&quot;background-color: #fff; color: #222; text-align: center;&quot;&gt;← Older revision&lt;/td&gt;
				&lt;td colspan=&quot;1&quot; style=&quot;background-color: #fff; color: #222; text-align: center;&quot;&gt;Revision as of 06:56, 7 February 2021&lt;/td&gt;
				&lt;/tr&gt;&lt;tr&gt;&lt;td colspan=&quot;2&quot; class=&quot;diff-notice&quot; lang=&quot;en&quot;&gt;&lt;div class=&quot;mw-diff-empty&quot;&gt;(No difference)&lt;/div&gt;
&lt;/td&gt;&lt;/tr&gt;&lt;/table&gt;</summary>
		<author><name>Admin</name></author>
		
	</entry>
	<entry>
		<id>http://sfsys.ru/index.php?title=Template:%D0%9F%D1%80%D0%B8%D0%BC%D0%B5%D1%80_%D0%BF%D0%BE%D0%B8%D1%81%D0%BA%D0%B0_%D0%B2_%D1%81%D0%BE%D1%80%D1%82%D0%B8%D1%80%D0%BE%D0%B2%D0%B0%D0%BD%D0%BD%D1%8B%D1%85_%D1%82%D0%B0%D0%B1%D0%BB%D0%B8%D1%86%D0%B0%D1%85&amp;diff=3727&amp;oldid=prev</id>
		<title>Admin at 16:08, 16 August 2019</title>
		<link rel="alternate" type="text/html" href="http://sfsys.ru/index.php?title=Template:%D0%9F%D1%80%D0%B8%D0%BC%D0%B5%D1%80_%D0%BF%D0%BE%D0%B8%D1%81%D0%BA%D0%B0_%D0%B2_%D1%81%D0%BE%D1%80%D1%82%D0%B8%D1%80%D0%BE%D0%B2%D0%B0%D0%BD%D0%BD%D1%8B%D1%85_%D1%82%D0%B0%D0%B1%D0%BB%D0%B8%D1%86%D0%B0%D1%85&amp;diff=3727&amp;oldid=prev"/>
		<updated>2019-08-16T16:08:01Z</updated>

		<summary type="html">&lt;p&gt;&lt;/p&gt;
&lt;p&gt;&lt;b&gt;New page&lt;/b&gt;&lt;/p&gt;&lt;div&gt;Данный пример сравнивает скорость работы функции FindAndGoto для сортированной и не сортированной таблиц. Внутри цикла поиска также происходит увеличение массива с помощью функции AddLineSorted для проверки корректности ее работы.&amp;lt;br /&amp;gt;&lt;br /&gt;
&lt;br /&gt;
См. также [[Template:Пример поиска множества значений в сортированных таблицах|Пример поиска множества значений в сортированных таблицах]].&lt;br /&gt;
&amp;lt;pre&amp;gt;&lt;br /&gt;
ProfilerClear();&lt;br /&gt;
ProfilerStart();&lt;br /&gt;
&lt;br /&gt;
randomize(1);&lt;br /&gt;
aTab:=Tab.Create(&amp;quot;Col1,Col2,Col3&amp;quot;);&lt;br /&gt;
For i:=1 To 100000 Do&lt;br /&gt;
  aTab.AddLineSorted(&amp;quot;Col1&amp;quot;,&amp;quot;Col1,Col2,Col3&amp;quot;,Random(10000),Random(10000),Random(10000));&lt;br /&gt;
EndDo;&lt;br /&gt;
&lt;br /&gt;
For i:=1 To 10000 Do&lt;br /&gt;
  j:=Random(aTab.Size())+1;&lt;br /&gt;
  aCol1:=aTab.Get(j,&amp;quot;Col1&amp;quot;);&lt;br /&gt;
  While _And(j&amp;gt;1,aTab.Get(j-1,&amp;quot;Col1&amp;quot;)=aCol1) Do&lt;br /&gt;
    j:=j-1;&lt;br /&gt;
  EndDo;&lt;br /&gt;
  aTab.FindAndGoto(aCol1,,&amp;quot;Col1&amp;quot;,1);&lt;br /&gt;
  If j&amp;lt;&amp;gt;aTab.CurLine Then&lt;br /&gt;
    Message(&amp;quot;Проблема при поиске значения!&amp;quot;,&amp;quot;!&amp;quot;);&lt;br /&gt;
  EndIf;&lt;br /&gt;
  //Добавление случайного значения внутри цикла поиска&lt;br /&gt;
  aTab.AddLineSorted(&amp;quot;Col1&amp;quot;,&amp;quot;Col1,Col2,Col3&amp;quot;,Random(10000),Random(10000),Random(10000));&lt;br /&gt;
EndDo;  &lt;br /&gt;
&lt;br /&gt;
randomize(1);&lt;br /&gt;
aTab:=Tab.Create(&amp;quot;Col1,Col2,Col3&amp;quot;);&lt;br /&gt;
For i:=1 To 100000 Do&lt;br /&gt;
  aTab.AddLine(&amp;quot;Col1,Col2,Col3&amp;quot;,Random(10000),Random(10000),Random(10000));&lt;br /&gt;
EndDo;&lt;br /&gt;
&lt;br /&gt;
aTab.Sort(&amp;quot;Col1&amp;quot;);&lt;br /&gt;
For i:=1 To 10000 Do&lt;br /&gt;
  j:=Random(aTab.Size())+1;&lt;br /&gt;
  aCol1:=aTab.Get(j,&amp;quot;Col1&amp;quot;);&lt;br /&gt;
  While _And(j&amp;gt;1,aTab.Get(j-1,&amp;quot;Col1&amp;quot;)=aCol1) Do&lt;br /&gt;
    j:=j-1;&lt;br /&gt;
  EndDo;&lt;br /&gt;
  aTab.FindAndGoto(aCol1,,&amp;quot;Col1&amp;quot;);&lt;br /&gt;
  If j&amp;lt;&amp;gt;aTab.CurLine Then&lt;br /&gt;
    Message(&amp;quot;Проблема при поиске значения (2)!&amp;quot;,&amp;quot;!&amp;quot;);&lt;br /&gt;
  EndIf;&lt;br /&gt;
  //Добавление случайного значения внутри цикла поиска&lt;br /&gt;
  aTab.AddLineSorted(&amp;quot;Col1&amp;quot;,&amp;quot;Col1,Col2,Col3&amp;quot;,Random(10000),Random(10000),Random(10000));&lt;br /&gt;
EndDo;  &lt;br /&gt;
&lt;br /&gt;
ProfilerStop();&lt;br /&gt;
debugbreak;&lt;br /&gt;
&lt;br /&gt;
Message(&amp;quot;Done!&amp;quot;);&lt;br /&gt;
//Для i5, конечные результаты для среднего времени исполнения каждой операции:&lt;br /&gt;
//aTab.AddLineSorted() (нач. заполнение)   -- 3.61 сек.&lt;br /&gt;
//aTab.AddLine() и aTab.Sort();            -- 3.45 сек.&lt;br /&gt;
//aTab.FindAndGoto(aCol1,,&amp;quot;Col1&amp;quot;,1);       -- 36 мс./10000&lt;br /&gt;
//aTab.FindAndGoto(aCol1,,&amp;quot;Col1&amp;quot;);         -- 35010 мс./10000&lt;br /&gt;
//&lt;br /&gt;
//Как показывает эксперимент, для больших таблиц поиск в сортированной таблице имеет очень большое преимущество перед поиском без учета сортировки (1000 раз в нашем случае), &lt;br /&gt;
//  преимущество будет только расти при увеличении количества строк в таблице&lt;br /&gt;
//Сортировка больших таблиц работает достаточно медленно, однако, использование функции AddLineSorted не имеет преимущества перед заполнением массива в случайном порядке, а затем его сортировкой.&lt;br /&gt;
//  AddLineSorted, однако, незаменим в случаях, когда необходимо добавлять строки в таблицу в цикле, в котором одновременно происходит сортированный поиск в этой же таблице.&lt;br /&gt;
&amp;lt;/pre&amp;gt;&lt;/div&gt;</summary>
		<author><name>Admin</name></author>
		
	</entry>
</feed>