91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

c# compareto 如何與其他排序算法配合

c#
小樊
81
2024-11-16 12:40:43
欄目: 編程語言

在C#中,CompareTo方法通常用于實現IComparable接口,以便對對象進行排序。然而,CompareTo方法本身并不是一種排序算法,而是一種比較兩個對象的方法。要將CompareTo與其他排序算法配合使用,您需要首先根據CompareTo的結果對對象進行排序,然后選擇合適的排序算法對已排序的對象進行進一步排序。

以下是一些常見的排序算法,以及如何將它們與CompareTo方法配合使用:

  1. 冒泡排序(Bubble Sort):
public void BubbleSort<T>(IList<T> list) where T : IComparable<T>
{
    int n = list.Count;
    for (int i = 0; i < n - 1; i++)
    {
        for (int j = 0; j < n - 1 - i; j++)
        {
            if (list[j].CompareTo(list[j + 1]) > 0)
            {
                T temp = list[j];
                list[j] = list[j + 1];
                list[j + 1] = temp;
            }
        }
    }
}
  1. 選擇排序(Selection Sort):
public void SelectionSort<T>(IList<T> list) where T : IComparable<T>
{
    int n = list.Count;
    for (int i = 0; i < n - 1; i++)
    {
        int minIndex = i;
        for (int j = i + 1; j < n; j++)
        {
            if (list[j].CompareTo(list[minIndex]) < 0)
            {
                minIndex = j;
            }
        }
        if (minIndex != i)
        {
            T temp = list[i];
            list[i] = list[minIndex];
            list[minIndex] = temp;
        }
    }
}
  1. 插入排序(Insertion Sort):
public void InsertionSort<T>(IList<T> list) where T : IComparable<T>
{
    int n = list.Count;
    for (int i = 1; i < n; i++)
    {
        T key = list[i];
        int j = i - 1;
        while (j >= 0 && list[j].CompareTo(key) > 0)
        {
            list[j + 1] = list[j];
            j--;
        }
        list[j + 1] = key;
    }
}
  1. 快速排序(Quick Sort):
public void QuickSort<T>(IList<T> list, int left, int right) where T : IComparable<T>
{
    if (left < right)
    {
        int pivotIndex = Partition(list, left, right);
        QuickSort(list, left, pivotIndex - 1);
        QuickSort(list, pivotIndex + 1, right);
    }
}

private int Partition<T>(IList<T> list, int left, int right) where T : IComparable<T>
{
    T pivot = list[right];
    int i = left - 1;
    for (int j = left; j < right; j++)
    {
        if (list[j].CompareTo(pivot) < 0)
        {
            i++;
            T temp = list[i];
            list[i] = list[j];
            list[j] = temp;
        }
    }
    T temp = list[i + 1];
    list[i + 1] = list[right];
    list[right] = temp;
    return i + 1;
}

在這些示例中,我們使用了CompareTo方法來比較對象,并根據比較結果對它們進行排序。您可以根據需要選擇合適的排序算法,并將其與CompareTo方法配合使用。

0
江津市| 聂拉木县| 湄潭县| 富宁县| 施甸县| 阿合奇县| 申扎县| 荔浦县| 溧水县| 电白县| 华阴市| 北票市| 太湖县| 光山县| 保靖县| 奉新县| 咸丰县| 偃师市| 仁怀市| 株洲县| 鲁山县| 大洼县| 武邑县| 虎林市| 闻喜县| 昆明市| 莲花县| 海林市| 油尖旺区| 紫云| 竹山县| 西城区| 苍梧县| 历史| 随州市| 沽源县| 新蔡县| 巨鹿县| 隆子县| 河曲县| 襄垣县|