<?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%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%81%D0%BF%D0%B8%D1%81%D0%BA%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%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%81%D0%BF%D0%B8%D1%81%D0%BA%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%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%81%D0%BF%D0%B8%D1%81%D0%BA%D0%B0%D1%85&amp;action=history"/>
	<updated>2026-04-04T13:31:26Z</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%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%81%D0%BF%D0%B8%D1%81%D0%BA%D0%B0%D1%85&amp;diff=3726&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%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%81%D0%BF%D0%B8%D1%81%D0%BA%D0%B0%D1%85&amp;diff=3726&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%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%81%D0%BF%D0%B8%D1%81%D0%BA%D0%B0%D1%85&amp;diff=3725&amp;oldid=prev</id>
		<title>Admin at 11:42, 8 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%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%81%D0%BF%D0%B8%D1%81%D0%BA%D0%B0%D1%85&amp;diff=3725&amp;oldid=prev"/>
		<updated>2019-08-08T11:42:06Z</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;Данный пример сравнивает скорость работы функции Find для сортированного и не сортированного списков. Внутри цикла поиска также происходит увеличение массива с помощью функции Add для проверки корректности ее работы.&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;
aList:=List.Create();&lt;br /&gt;
For i:=1 To 100000 Do&lt;br /&gt;
  aList.Add(Random(10000));&lt;br /&gt;
EndDo;&lt;br /&gt;
&lt;br /&gt;
aList.Sort();&lt;br /&gt;
For i:=1 To 10000 Do&lt;br /&gt;
  j:=Random(aList.Size())+1;&lt;br /&gt;
  aNum:=aList.Get(j);&lt;br /&gt;
  While _And(j&amp;gt;1,aList.Get(j-1)=aNum) Do&lt;br /&gt;
    j:=j-1;&lt;br /&gt;
  EndDo;&lt;br /&gt;
  j2:=aList.Find(aNum,,1);&lt;br /&gt;
  If j&amp;lt;&amp;gt;j2 Then&lt;br /&gt;
    Message(&amp;quot;Проблема при поиске значения!&amp;quot;,&amp;quot;!&amp;quot;);&lt;br /&gt;
  EndIf;&lt;br /&gt;
  //Добавление случайного значения внутри цикла поиска&lt;br /&gt;
  aList.Add(Random(10000),,,1);&lt;br /&gt;
EndDo;  &lt;br /&gt;
&lt;br /&gt;
randomize(1);&lt;br /&gt;
aList:=List.Create();&lt;br /&gt;
For i:=1 To 100000 Do&lt;br /&gt;
  aList.Add(Random(10000));&lt;br /&gt;
EndDo;&lt;br /&gt;
&lt;br /&gt;
aList.Sort();&lt;br /&gt;
For i:=1 To 10000 Do&lt;br /&gt;
  j:=Random(aList.Size())+1;&lt;br /&gt;
  aNum:=aList.Get(j);&lt;br /&gt;
  While _And(j&amp;gt;1,aList.Get(j-1)=aNum) Do&lt;br /&gt;
    j:=j-1;&lt;br /&gt;
  EndDo;&lt;br /&gt;
  j2:=aList.Find(aNum);&lt;br /&gt;
  If j&amp;lt;&amp;gt;j2 Then&lt;br /&gt;
    Message(&amp;quot;Проблема при поиске значения (2)!&amp;quot;,&amp;quot;!&amp;quot;);&lt;br /&gt;
  EndIf;&lt;br /&gt;
  //Добавление случайного значения внутри цикла поиска, в данном примере нас интересует сравнительная скорость работы функции Add с сортировкой, поэтому&lt;br /&gt;
  //  этот блок не имеет большого значения, кроме как поддержание соответствия может циклами&lt;br /&gt;
  //Дополнение: j2 не будет возвращать 0 для последовательности, инициированной randomize(1), в ином случае, возможно, потребуется дополнительная проверка&lt;br /&gt;
  j:=Random(10000);&lt;br /&gt;
  j2:=aList.Find(j,,1);&lt;br /&gt;
  aList.Insert(j2,j);&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;
//aList.Sort();                   -- 3 сек./1&lt;br /&gt;
//j2:=aList.Find(aNum,,1);        -- 30.5 мс./10000&lt;br /&gt;
//aList.Add(Random(10000),,,1);   -- 640 мс./10000&lt;br /&gt;
//j2:=aList.Find(aNum);           -- 31733 мс./10000&lt;br /&gt;
//aList.Insert(j2,j);             -- 690 мс./10000&lt;br /&gt;
//&lt;br /&gt;
//Как показывает эксперимент, для больших массивов поиск в сортированном массиве имеет очень большое преимущество перед поиском без учета сортировки (1000 раз в нашем случае), &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>