我正在尝试解决一个像
这样的数据结构有用的问题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];
即。
但我看不出这样的事情存在?我看到有一些令人困惑的SortedList<T,U>
然后是一个接口SortedList
,但这些都不是我正在寻找的。 p>
答案 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);