C#没有SortedList <t>?

时间:2017-01-28 06:51:42

标签: c# .net algorithm data-structures

我正在尝试解决一个像

这样的数据结构有用的问题
var list = new SortedList<int>(); 
list.Add(3); // list = { 3 } 
list.Add(1); // list = { 1, 3 }
list.Add(2); // list = { 1, 2, 3 }
int median = list[list.Length / 2];

即。

  • O(n)插入
  • O(1)按索引查找

但我看不出这样的事情存在?我看到有一些令人困惑的SortedList<T,U>然后是一个接口SortedList,但这些都不是我正在寻找的。

1 个答案:

答案 0 :(得分:0)

.NET框架中的排序列表是一个关联列表(即用于键/值对)。如果您使用其二进制搜索功能,则可以使用常规List<T>,如果您始终对列表进行排序,则可以使用该功能。您可以将其封装在扩展方法中:

static class SortedListExtensions {
    public static void SortedAdd<T>(this List<T> list, T value) {
        int insertIndex = list.BinarySearch(value);
        if (value < 0) {
            value = ~value;
        }
        list.Insert(insertIndex, value);
    }

    //Added bonus: a faster Contains method
    public static bool SortedContains<T>(this List<T> list, T value) {
        return list.BinarySearch(value) >= 0;
    }
}


List<int> values = new List<int>();
values.SortedAdd(3);
values.SortedAdd(1);
values.SortedAdd(2);