我有2D锯齿状阵列。我希望按行排序。
我搜索过并找到按列排序的代码
private static void Sort<T>(T[][] data, int col)
{
Comparer<T> comparer = Comparer<T>.Default;
Array.Sort<T[]>(data, (x,y) => comparer.Compare(x[col],y[col]));
}
我可以根据任何行调整它吗?
感谢任何帮助。
我的锯齿状阵列样本(已添加)
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
namespace ConsoleApplication3
{
class Program
{
static void Main(string[] args)
{
int n = 10;
int[][] capm = new int[3][];
for (int i = 0; i <= 2; i++)
{
capm[i] = new int[n + 1];
}
Random rand = new Random();
for (int i = 1; i <= n; i++)
{
capm[1][i] = i;
}
for (int i = 1; i <= n; i++)
{
capm[2][i] = rand.Next(1, 6);
}
Sort(capm, 2);
Console.ReadLine();
}
private static void Sort<T>(T[][] data, int col)
{
data = data.OrderBy(i => i[col]).ToArray();
}
}
}
@Dani&amp; @Martin我希望我的锯齿状数组按capm [2] []排序。
答案 0 :(得分:4)
我能想到的唯一方法就是按索引数组排序:
private static void Sort<T>(T[][] data, int row)
{
int[] Indices = new int[data[0].Length];
for(int i = 0; i < Indices.Length; i++)
Indices[i] = i;
Comparer<T> comparer = Comparer<T>.Default;
Array.Sort(Indices, (x, y) => comparer.Compare(data[row][x], data[row][y]);
for(int i = 0; i < data.Length; i++)
{
T[] OldRow = (T[])data[i].Clone();
for(int j = 0; j < OldRow.Length; j++)
data[i][j] = OldRow[i][Indices[j]];
}
}
答案 1 :(得分:1)
鉴于您使用的是锯齿状数组,这将按第3项排序..但如果您想保证每行具有相同数量的列,则2D数组可能更好......如果您有一个数组没有第3列的数组,这将失败!
private static void Sort<T>(T[][] data, int col)
{
data = data.OrderBy(i => i[col]).ToArray();
}
编辑:
为了对新数据引用做任何事情,您需要返回它或通过引用传递参数:
private static void Sort<T>(ref T[][] data, int col)
{
data = data.OrderBy(i => i[col]).ToArray();
}
数组本身未排序,创建了新的排序数组