<?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%BC%D0%BD%D0%BE%D0%B6%D0%B5%D1%81%D1%82%D0%B2%D0%B0_%D0%B7%D0%BD%D0%B0%D1%87%D0%B5%D0%BD%D0%B8%D0%B9_%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%BC%D0%BD%D0%BE%D0%B6%D0%B5%D1%81%D1%82%D0%B2%D0%B0_%D0%B7%D0%BD%D0%B0%D1%87%D0%B5%D0%BD%D0%B8%D0%B9_%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%BC%D0%BD%D0%BE%D0%B6%D0%B5%D1%81%D1%82%D0%B2%D0%B0_%D0%B7%D0%BD%D0%B0%D1%87%D0%B5%D0%BD%D0%B8%D0%B9_%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-04T15:48:14Z</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%BC%D0%BD%D0%BE%D0%B6%D0%B5%D1%81%D1%82%D0%B2%D0%B0_%D0%B7%D0%BD%D0%B0%D1%87%D0%B5%D0%BD%D0%B8%D0%B9_%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=3730&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%BC%D0%BD%D0%BE%D0%B6%D0%B5%D1%81%D1%82%D0%B2%D0%B0_%D0%B7%D0%BD%D0%B0%D1%87%D0%B5%D0%BD%D0%B8%D0%B9_%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=3730&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%BC%D0%BD%D0%BE%D0%B6%D0%B5%D1%81%D1%82%D0%B2%D0%B0_%D0%B7%D0%BD%D0%B0%D1%87%D0%B5%D0%BD%D0%B8%D0%B9_%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=3729&amp;oldid=prev</id>
		<title>Admin at 16:11, 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%BC%D0%BD%D0%BE%D0%B6%D0%B5%D1%81%D1%82%D0%B2%D0%B0_%D0%B7%D0%BD%D0%B0%D1%87%D0%B5%D0%BD%D0%B8%D0%B9_%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=3729&amp;oldid=prev"/>
		<updated>2019-08-16T16:11:13Z</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;Данный пример сравнивает скорость работы функции LocateAndGoto для сортированной и не сортированной таблиц. Внутри цикла поиска также происходит увеличение массива с помощью функции AddLineSorted для проверки корректности ее работы.&amp;lt;br /&amp;gt;&lt;br /&gt;
См. также [[Template:Пример поиска в сортированных таблицах|Пример поиска в сортированных таблицах]].&lt;br /&gt;
&lt;br /&gt;
&amp;lt;pre&amp;gt;&lt;br /&gt;
  Function TestTable(aTab)&lt;br /&gt;
    for i:=1 to 25000 Do&lt;br /&gt;
      j:=Random(10000)+1;&lt;br /&gt;
      aTab.CurLine:=j;&lt;br /&gt;
      while _And(j&amp;gt;1,aTab.Get(j-1,&amp;quot;b1&amp;quot;)=aTab.b1,aTab.Get(j-1,&amp;quot;b2&amp;quot;)=aTab.b2,aTab.Get(j-1,&amp;quot;b3&amp;quot;)=aTab.b3,aTab.Get(j-1,&amp;quot;b4&amp;quot;)=aTab.b4,aTab.Get(j-1,&amp;quot;b5&amp;quot;)=aTab.b5) Do&lt;br /&gt;
        j:=j-1;&lt;br /&gt;
      EndDo;&lt;br /&gt;
      j2:=aTab.Locate(&amp;quot;b1,b2,b3,b4,b5&amp;quot;,aTab.b1,aTab.b2,aTab.b3,aTab.b4,aTab.b5);&lt;br /&gt;
      if j&amp;lt;&amp;gt;j2 then &lt;br /&gt;
        Message(&amp;quot;Проблема, невозможно найти индекс &amp;quot;+j+&amp;quot; (простой поиск)&amp;quot;,&amp;quot;!&amp;quot;);&lt;br /&gt;
        Exit 0,2;&lt;br /&gt;
      EndIf;&lt;br /&gt;
      j2:=aTab.Locate(&amp;quot;b1,b2,b3,b4,b5&amp;quot;,aTab.b1,aTab.b2,aTab.b3,aTab.b4,aTab.b5,1);&lt;br /&gt;
      if j&amp;lt;&amp;gt;j2 then &lt;br /&gt;
        Message(&amp;quot;Проблема, невозможно найти индекс &amp;quot;+j+&amp;quot; (поиск с сортировкой)&amp;quot;,&amp;quot;!&amp;quot;);&lt;br /&gt;
        Exit 0,2;&lt;br /&gt;
      EndIf;&lt;br /&gt;
    EndDo;&lt;br /&gt;
  EndFunction  &lt;br /&gt;
&lt;br /&gt;
Randomize(1);&lt;br /&gt;
aTab:=Tab.Create(&amp;quot;b1,b2,b3,b4,b5&amp;quot;);&lt;br /&gt;
bTab:=Tab.Create(&amp;quot;b1,b2,b3,b4,b5&amp;quot;);&lt;br /&gt;
For i:=1 To 100000 Do&lt;br /&gt;
  bTab.Addline(&amp;quot;b1,b2,b3,b4,b5&amp;quot;,random(10),random(10),random(10),random(10),random(10));&lt;br /&gt;
  aTab.Addline(&amp;quot;b1,b2,b3,b4,b5&amp;quot;,random(1000),random(1000),random(1000),random(1000),random(1000));&lt;br /&gt;
EndDo;&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
ProfilerClear();&lt;br /&gt;
ProfilerStart();&lt;br /&gt;
&lt;br /&gt;
aTab.Sort(&amp;quot;b1,b2,b3,b4,b5&amp;quot;);&lt;br /&gt;
bTab.Sort(&amp;quot;b1,b2,b3,b4,b5&amp;quot;);&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
TestTable(aTab);&lt;br /&gt;
TestTable(bTab);&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.Locate(&amp;quot;b1,b2,b3,b4,b5&amp;quot;,...)        -- 16.45 сек./50000&lt;br /&gt;
//aTab.Locate(&amp;quot;b1,b2,b3,b4,b5&amp;quot;,...,1)      -- 708 мс./50000&lt;br /&gt;
//aTab.Sort();                             -- 3.90 с.&lt;br /&gt;
//bTab.Sort();                             -- 3.92 с.&lt;br /&gt;
//TestTable(aTab);                         -- 5.0 с.&lt;br /&gt;
//TestTable(bTab);                         -- 13.4 с.&lt;br /&gt;
//&lt;br /&gt;
//Как показывает эксперимент, для больших таблиц поиск в сортированной таблице имеет большое преимущество перед поиском без учета сортировки &lt;br /&gt;
//  (23 раза в нашем случае для суммы обеих таблиц), преимущество будет только расти при увеличении количества строк в таблице.&lt;br /&gt;
//Сортировка больших таблиц работает достаточно медленно, однако, она не зависит от типа данных в таблице.&lt;br /&gt;
//Для таблиц с большим количеством одинаковых данных (bTab) поиск происходит гораздо медленнее, чем для таблиц, где данные сильно отличаются. Дело в том, что Locate при проверке строки &lt;br /&gt;
//  начинает проверку с первого столбца, если он совпадает с искомым значением, переходит ко второму и т.д. Если в таблице много одинаковых значений для многих строк необходимо большее &lt;br /&gt;
//  число сравнений, чем, для таблиц, где одинаковых значений гораздо меньше. Поэтому, при таком поиске первыми выгодно указывать столбцы, которые содержат наиболее разнообразную информацию&lt;br /&gt;
//Это касается как сортированного, так и не сортированного поиска, однако, сортированный поиск менее подвержен влиянию распределения данных в таблице поиска.&lt;br /&gt;
&amp;lt;/pre&amp;gt;&lt;/div&gt;</summary>
		<author><name>Admin</name></author>
		
	</entry>
</feed>