Это скорее вопрос типа «Можете ли вы объяснить этот», чем что-либо еще.
Я столкнулся с проблемой на работе, когда мы использовали значения NaN в таблице, но когда таблица была отсортирована, это получилось очень странным, странным образом. Я подумал, что NaN что-то напортачивает, поэтому я написал тестовое приложение, чтобы проверить, правда ли это. Это то, что я сделал.
static void Main(string[] args)
{
double[] someArray = { 4.0, 2.0, double.NaN, 1.0, 5.0, 3.0, double.NaN, 10.0, 9.0, 8.0 };
foreach (double db in someArray)
{
Console.WriteLine(db);
}
Array.Sort(someArray);
Console.WriteLine("\n\n");
foreach (double db in someArray)
{
Console.WriteLine(db);
}
Console.ReadLine();
}
Что дало результат:
До:
4,2,NaN,1,5,3,NaN,10,9,8
После:
1,4,NaN,2,3,5,8,9,10,NaN
Так что да, NaN каким-то образом заставил отсортированный массив странным образом сортировать.
Процитирую Фрая; «Почему это?»