C# сортировка массива с цифрами
Здравствуйте, я хочу отсортировать массив, который содержит это:
String[] info = new String[5]{"6,j", "7,d", "12,s", "4,h", "14,s" };
Но если я использую это:
Array.Sort(info);
Выход становится:
"7,d"
"6,j"
"4,h"
"14,s"
"12,s"
Но я не буду вывод:
"14,s"
"12,s"
"7,d"
"6,j"
"4,h"
Какой самый простой способ сделать это в / с C#??
И я не могу заставить алфавитно-цифровую сортировку работать, когда я делаю так:
Array.Sort(info, new AlphanumComparatorFast());
тип или пространство имен "AlphanumComparatorFast" не может быть найдено, если вы пропустили директиву using или ссылку на сборку
это ошибка, которую я получаю...
6 ответов
Попробуйте с:
var sortedArray = info.OrderBy(s=>int.Parse(s.Split(',')[0])).ToArray();
Это отсортировано только по числовой части, но вы можете уточнить этот пример. Этот код строго предполагает, что всегда есть разделитель запятых, это может быть проблемой в производственном процессе, сделайте более точную обработку ошибок. Если массив содержит некоторые элементы, которые не соответствуют исключению, при условии, что допустимо игнорировать ошибочные элементы, мы можем написать:
var sortedArray = info.Where(k=>!string.IsNullOrEmpty(k)&&k.IndexOf(",")!=-1)
.OrderBy(s=>int.Parse(s.Split(',')[0])).ToArray();
Если вы используете.NET 2.0 и не можете использовать Linq, вы можете попробовать:
String[] info = new String[5] { "6,j", "7,d", "12,s", "4,h", "14,s" };
Array.Sort(info, delegate(string a, string b)
{
int numberA = int.Parse(a.Substring(0, a.IndexOf(',')));
int numberB = int.Parse(b.Substring(0, b.IndexOf(',')));
string stringA = a.Substring(a.IndexOf(','));
string stringB = b.Substring(b.IndexOf(','));
if (numberA > numberB) return -1;
else if (numberA < numberB) return 1;
else return stringA.CompareTo(stringB);
}
);
Предполагается, что разделитель всегда является запятой, при необходимости добавьте свой собственный код проверки.
Вместо того, чтобы представлять их как строки, вы можете проанализировать их и разделить на классы. Внедрите IComparable, и вы отсортированы. Пан полностью предназначен.
Или реализуйте свой собственный компаратор сортировки, чтобы проанализировать объекты и затем отсортировать их правильно.
Вы можете использовать пользовательский компаратор
public class MyComparer : IComparer<string>
{
public int Compare(string x, string y)
{
// return value greater than zero if x is greater than y
// return zero if x is equal to y
// return value less than zero if x is less than y
}
}
и вы можете использовать свой компаратор, как так
Array.Sort(info, new MyComparer());
Сортировка по числовой части строки:
var info = new String[5]{"6,j", "7,d", "12,s", "4,h", "14,s" };
foreach (var item in info.OrderByDescending (x =>
int.Parse(x.Substring(0, x.IndexOf(',')))))
{
Console.WriteLine(item);
}
Вот немного кода, который я написал некоторое время назад, я уверен, что есть более эффективный способ сделать это, но это, безусловно, работает. Чтобы использовать его, включите:
using System.Linq;
затем вызовите запрос linq:
Array.Sort(info,delegate(string x, string y){return NaturalCompare(y,x)}); sort as you seem to want
и, конечно, включить соответствующий метод:
public int NaturalCompare(string x, string y)
{
string[] x1, y1;
x1 = Regex.Split(x.Replace(" ", ""), "([0-9]+)");
y1 = Regex.Split(y.Replace(" ", ""), "([0-9]+)");
for (int i = 0; i < x1.Length && i < y1.Length; i++)
{
if (!x1[i].Equals(y1[i]))
{
return PartCompare(x1[i], y1[i]);
}
}
return x.CompareTo(y);
}
private int PartCompare(string left, string right)
{
int x, y;
if (int.TryParse(left, out x) && int.TryParse(right, out y))
return x.CompareTo(y);
return left.CompareTo(right);
}