这个题目,不方便使用递归!
直觉告诉我,可以用两层遍历,外面一层是维数,里面一层是每一维。但实际上,要做起来很难!
最后决定最外层循环用元素个数,里面配合使用维数的循环,最终解决问题!
static void ArrEnum(Array arr, Action<Int32[]> func)
{
Int32[] ix = new Int32[arr.Rank];
Int32 rank = 0;
for (int i = 0; i < arr.Length; i++)
{
// 当前层以下都清零
for (int j = rank + 1; j < arr.Rank; j++)
{
ix[j] = 0;
}
// 设置为最底层
rank = arr.Rank - 1;
//do something
//arr.SetValue(i, ix);
func(ix);
// 当前层递加
ix[rank]++;
// 如果超过上限,则减少层次
while (ix[rank] >= arr.GetLength(rank))
{
rank--;
if (rank < 0) break;
ix[rank]++;
}
}
}
static void Test2()
{
Int32[, , ,] arr = new Int32[24, 24, 24, 24];
Int32 n=1;
ArrEnum(arr, ix => arr.SetValue(n++, ix));
ArrEnum(arr, delegate(Int32[] ix)
{
Console.Write("[");
for (int i = 0; i < ix.Length; i++)
{
if (i > 0) Console.Write(", ");
Console.Write(ix[i]);
}
Console.Write("]\t");
Console.WriteLine(arr.GetValue(ix));
});
}