Сортировка списка, составленного из массива

Я нахожусь в середине проекта, и я застрял на проблеме,

мне нужно отсортировать список в C#, структура списка
public List < double[] > DataList = new List < double[] >();

Теперь я хочу отсортировать этот список на основе последнего индекса двойного массива в списке

лайк

2|3|5|6|8

2|3|5|6|9

2|3|5|6|5

2|3|5|6|12

на выходе должно быть что-то вроде этого

2|3|5|6|12

2|3|5|6|9

2|3|5|6|8

2|3|5|6|5

3 ответа

Решение

Используйте LINQ:

// reproduce data
List<double[]> DataList = new List<double[]>();
DataList.Add(new double[] { 2, 3, 5, 6, 8 });
DataList.Add(new double[] { 2, 3, 5, 6, 9 });
DataList.Add(new double[] { 2, 3, 5, 6, 5 });
DataList.Add(new double[] { 2, 3, 5, 6, 12 });

var ordered = DataList.OrderByDescending(l => l.Last());

l будет соответствовать каждому элементу в DataList, С l.Last() Вы используете последний элемент в качестве критерия сортировки.

Также с помощью Linq:

var tList = new List<double[]>();
tList.Add(new double[] {2,3,4,5,8});
tList.Add(new double[] {2,3,4,5,9});
tList.Add(new double[] {2,3,4,5,5});
tList.Add(new double[] {2,3,4,5,12});

var t = from element in tList
        orderby element.Last() descending
        select element;
var tResults = t.ToList();

Это сортировка старой школы без использования LINQ.

        List<double[]> DataList = new List<double[]>();
        private void button1_Click(object sender, EventArgs e)
        {
            DataList.Add(new double[] { 2, 3, 5, 6, 8 });
            DataList.Add(new double[] { 2, 3, 5, 6, 9 });
            DataList.Add(new double[] { 2, 3, 5, 6, 5 });
            DataList.Add(new double[] { 2, 3, 5, 6, 12 });
            DataList.Sort(new DoubleArrayComparer());
            DataList.Reverse();
        }
        class DoubleArrayComparer : IComparer<double[]>
        {
            public int Compare(double[] x, double[] y)
            {
                if(x.Length>0 && y.Length>0)
                {
                    if(x[x.Length-1] > y[y.Length-1])
                        return 1;
                    else if(x[x.Length-1] < y[y.Length-1])
                        return -1;
                    else
                        return 0;

                }
                else if(x.Length == 0 && y.Length!=0)
                    return -1;
                else if(y.Length == 0 && x.Length!=0)
                    return 1;
                else
                    return 0;
            }
        }
Другие вопросы по тегам