<?xml version="1.0"?>
<feed xmlns="http://www.w3.org/2005/Atom" xml:lang="ru">
		<id>http://nfex.ru/index.php?action=history&amp;feed=atom&amp;title=Csharp%2FCSharp_Tutorial%2FData_Structure%2FSort</id>
		<title>Csharp/CSharp Tutorial/Data Structure/Sort - История изменений</title>
		<link rel="self" type="application/atom+xml" href="http://nfex.ru/index.php?action=history&amp;feed=atom&amp;title=Csharp%2FCSharp_Tutorial%2FData_Structure%2FSort"/>
		<link rel="alternate" type="text/html" href="http://nfex.ru/index.php?title=Csharp/CSharp_Tutorial/Data_Structure/Sort&amp;action=history"/>
		<updated>2026-04-30T05:04:57Z</updated>
		<subtitle>История изменений этой страницы в вики</subtitle>
		<generator>MediaWiki 1.30.0</generator>

	<entry>
		<id>http://nfex.ru/index.php?title=Csharp/CSharp_Tutorial/Data_Structure/Sort&amp;diff=5515&amp;oldid=prev</id>
		<title> в 15:31, 26 мая 2010</title>
		<link rel="alternate" type="text/html" href="http://nfex.ru/index.php?title=Csharp/CSharp_Tutorial/Data_Structure/Sort&amp;diff=5515&amp;oldid=prev"/>
				<updated>2010-05-26T15:31:53Z</updated>
		
		<summary type="html">&lt;p&gt;&lt;/p&gt;
&lt;table class=&quot;diff diff-contentalign-left&quot; data-mw=&quot;interface&quot;&gt;
				&lt;tr style=&quot;vertical-align: top;&quot; lang=&quot;ru&quot;&gt;
				&lt;td colspan=&quot;1&quot; style=&quot;background-color: white; color:black; text-align: center;&quot;&gt;← Предыдущая&lt;/td&gt;
				&lt;td colspan=&quot;1&quot; style=&quot;background-color: white; color:black; text-align: center;&quot;&gt;Версия 15:31, 26 мая 2010&lt;/td&gt;
				&lt;/tr&gt;&lt;tr&gt;&lt;td colspan=&quot;2&quot; style=&quot;text-align: center;&quot; lang=&quot;ru&quot;&gt;&lt;div class=&quot;mw-diff-empty&quot;&gt;(нет различий)&lt;/div&gt;
&lt;/td&gt;&lt;/tr&gt;&lt;/table&gt;</summary>
			</entry>

	<entry>
		<id>http://nfex.ru/index.php?title=Csharp/CSharp_Tutorial/Data_Structure/Sort&amp;diff=5516&amp;oldid=prev</id>
		<title>Admin: 1 версия</title>
		<link rel="alternate" type="text/html" href="http://nfex.ru/index.php?title=Csharp/CSharp_Tutorial/Data_Structure/Sort&amp;diff=5516&amp;oldid=prev"/>
				<updated>2010-05-26T12:15:47Z</updated>
		
		<summary type="html">&lt;p&gt;1 версия&lt;/p&gt;
&lt;p&gt;&lt;b&gt;Новая страница&lt;/b&gt;&lt;/p&gt;&lt;div&gt;==Bubble sort object array==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
&amp;lt;source lang=&amp;quot;csharp&amp;quot;&amp;gt;using System;&lt;br /&gt;
delegate bool CompareOp(object lhs, object rhs);&lt;br /&gt;
class MainEntryPoint {&lt;br /&gt;
    static void Main() {&lt;br /&gt;
        Employee[] employees = {&lt;br /&gt;
              new Employee(&amp;quot;B&amp;quot;, 20000),&lt;br /&gt;
              new Employee(&amp;quot;E&amp;quot;, 10000),&lt;br /&gt;
              new Employee(&amp;quot;D&amp;quot;, 25000),&lt;br /&gt;
              new Employee(&amp;quot;W&amp;quot;, (decimal)1000000.38),&lt;br /&gt;
              new Employee(&amp;quot;F&amp;quot;, 23000),&lt;br /&gt;
              new Employee(&amp;quot;R&amp;quot;&amp;quot;, 50000)};&lt;br /&gt;
        CompareOp employeeCompareOp = new CompareOp(Employee.RhsIsGreater);&lt;br /&gt;
        BubbleSorter.Sort(employees, employeeCompareOp);&lt;br /&gt;
        for (int i = 0; i &amp;lt; employees.Length; i++)&lt;br /&gt;
            Console.WriteLine(employees[i].ToString());&lt;br /&gt;
        Console.ReadLine();&lt;br /&gt;
    }&lt;br /&gt;
}&lt;br /&gt;
class Employee{&lt;br /&gt;
    private string name;&lt;br /&gt;
    private decimal salary;&lt;br /&gt;
    public Employee(string name, decimal salary) {&lt;br /&gt;
        this.name = name;&lt;br /&gt;
        this.salary = salary;&lt;br /&gt;
    }&lt;br /&gt;
    public override string ToString() {&lt;br /&gt;
        return string.Format(name + &amp;quot;, {0:C}&amp;quot;, salary);&lt;br /&gt;
    }&lt;br /&gt;
    public static bool RhsIsGreater(object lhs, object rhs) {&lt;br /&gt;
        Employee empLhs = (Employee)lhs;&lt;br /&gt;
        Employee empRhs = (Employee)rhs;&lt;br /&gt;
        return (empRhs.salary &amp;gt; empLhs.salary) ? true : false;&lt;br /&gt;
    }&lt;br /&gt;
}&lt;br /&gt;
class BubbleSorter {&lt;br /&gt;
    static public void Sort(object[] sortArray, CompareOp gtMethod) {&lt;br /&gt;
        for (int i = 0; i &amp;lt; sortArray.Length; i++) {&lt;br /&gt;
            for (int j = i + 1; j &amp;lt; sortArray.Length; j++) {&lt;br /&gt;
                if (gtMethod(sortArray[j], sortArray[i])) {&lt;br /&gt;
                    object temp = sortArray[i];&lt;br /&gt;
                    sortArray[i] = sortArray[j];&lt;br /&gt;
                    sortArray[j] = temp;&lt;br /&gt;
                }&lt;br /&gt;
            }&lt;br /&gt;
        }&lt;br /&gt;
    }&lt;br /&gt;
}&amp;lt;/source&amp;gt;&lt;br /&gt;
&lt;br /&gt;
==Your own quick sort==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
&amp;lt;source lang=&amp;quot;csharp&amp;quot;&amp;gt;using System;&lt;br /&gt;
using System.Collections.Generic;&lt;br /&gt;
class MainClass{&lt;br /&gt;
   public static void Main(){&lt;br /&gt;
       MyQuickSort&amp;lt;int&amp;gt; iSort = new MyQuickSort&amp;lt;int&amp;gt;(new int[]{2,1,3});&lt;br /&gt;
       iSort.Sort();    &lt;br /&gt;
    &lt;br /&gt;
   }&lt;br /&gt;
}&lt;br /&gt;
&lt;br /&gt;
class MyQuickSort&amp;lt;T&amp;gt; where T : IComparable&lt;br /&gt;
{&lt;br /&gt;
    T[] data;&lt;br /&gt;
    public MyQuickSort(T[] values)&lt;br /&gt;
    {&lt;br /&gt;
        data = values;&lt;br /&gt;
    }&lt;br /&gt;
    private void doSort(int first, int last)&lt;br /&gt;
    {&lt;br /&gt;
        if (first == last)&lt;br /&gt;
        {&lt;br /&gt;
            return;   &lt;br /&gt;
        }&lt;br /&gt;
        else&lt;br /&gt;
        {&lt;br /&gt;
            int pivot = getPivotPoint(first, last);&lt;br /&gt;
            if (pivot &amp;gt; first)&lt;br /&gt;
                doSort(first, pivot - 1);&lt;br /&gt;
            if (pivot &amp;lt; last)&lt;br /&gt;
                doSort(pivot + 1, last);&lt;br /&gt;
        }&lt;br /&gt;
    }&lt;br /&gt;
    private int getPivotPoint(int first, int last)&lt;br /&gt;
    {&lt;br /&gt;
        int pivot = first;&lt;br /&gt;
        int start = first;  &lt;br /&gt;
        int end = last;&lt;br /&gt;
        if (last - first &amp;gt;= 1){&lt;br /&gt;
            while (end &amp;gt; start)&lt;br /&gt;
            {&lt;br /&gt;
                while (data[pivot].rupareTo(data[start]) &amp;gt;= 0 &amp;amp;&amp;amp; start &amp;lt;= last &amp;amp;&amp;amp; end &amp;gt; start)&lt;br /&gt;
                    start++;&lt;br /&gt;
                while (data[pivot].rupareTo(data[end]) &amp;lt;= 0 &amp;amp;&amp;amp; end &amp;gt;= first &amp;amp;&amp;amp; end &amp;gt;= start)&lt;br /&gt;
                    end--;&lt;br /&gt;
                if (end &amp;gt; start)&lt;br /&gt;
                    swap(start, end);&lt;br /&gt;
            }&lt;br /&gt;
            swap(first, end);&lt;br /&gt;
            doSort(first, end - 1);&lt;br /&gt;
        }&lt;br /&gt;
        return end;&lt;br /&gt;
    }&lt;br /&gt;
    private void swap(int pos1, int pos2)&lt;br /&gt;
    {&lt;br /&gt;
        T temp;&lt;br /&gt;
        temp = data[pos1];&lt;br /&gt;
        data[pos1] = data[pos2];&lt;br /&gt;
        data[pos2] = temp;&lt;br /&gt;
    }&lt;br /&gt;
    public void Sort()&lt;br /&gt;
    {&lt;br /&gt;
        int len = data.Length;&lt;br /&gt;
        if (len &amp;lt; 2)      // Enough to sort?&lt;br /&gt;
            return;&lt;br /&gt;
        doSort(0, data.Length - 1);&lt;br /&gt;
    }&lt;br /&gt;
}&amp;lt;/source&amp;gt;&lt;/div&gt;</summary>
		<author><name>Admin</name></author>	</entry>

	</feed>