以自定义方式重新排序数组

时间:2013-03-22 03:46:31

标签: c# .net list split

我有一系列项目按以下顺序打印到pdf。 让我们说:例如:

lines = {1, 2, 3, 
         4, 5, 6, 
         7, 8, 9, 
         10}

是我的数组的内容。

但是我想将数组中项目的顺序更改为

  {1, 4, 7,
   2, 5, 8, 
   3, 6, 9, 
   10}

然后我将这个数组传递给我的打印引擎。基本上,如果数组中有超过3个项目,我的新代码应重新排序。

有人可以帮我弄清楚那个逻辑。

由于

2 个答案:

答案 0 :(得分:4)

按行索引的模数和行数对行进行排序。

public static ICollection<T> Sort<T>(ICollection<T> lines, int columns)
{
    var rows = lines.Count/columns;
    if (rows == 0)
    {
        return lines;
    }
    return lines.Select((line, i) => new {line, i})
                .OrderBy(item => item.i < columns*rows ? item.i%rows : rows)
                .Select(item => item.line)
                .ToList();
}

编辑:或者您可以使用迭代器方法和列表的索引器而不是LINQ:

public static IEnumerable<T> Sort<T>(IList<T> lines, int columns)
{
    var rows = lines.Count/columns;
    for (var i = 0; i < lines.Count; i++)
    {
        var index = rows > 0 && i < columns*rows
            ? (i%columns)*rows + i/columns
            : i;
        yield return lines[index];
    }
}

答案 1 :(得分:0)

假设“对于线性数组,假设每9个元素形成3x3矩阵转置每个子序列,保持其余为”:

// assuming T[] items;
var toTranspose = (items.Count() / 9) * 9;
var remap = new int[]{1, 4, 7, 2, 5, 8, 3, 6, 9 };

var result = Enumerable.Range(0, toTranspose)
  .Select(pos => items[(pos / 9) * 9 + (remap[pos % 9] - 1)])
  .Concat(items.Skip(toTranspose)
  .ToArray();

代码摘要:

  • 获取需要移动的项目数(这是9个项目的组数int numberOfGroup = Count()/9;,乘以组大小)
  • remap数组中进行自定义转换(请注意索引从样本中复制,实际上是逐个复制,因此计算索引中为-1
  • toTranspose下的每个元素索引获取相应组中的源元素,并使用remap应用转换。
  • 最后Concat余下。

注意:

  • 如果需要,可以轻松提供自定义转换或内联转置。
  • 无法将转换应用于最后一个部分组,因为元素必须转到不存在的位置。