您的位置:首页 > 其它

如何遍历维数和各维上限未定的多维数组

2011-05-18 14:20 218 查看
这个题目,不方便使用递归!

直觉告诉我,可以用两层遍历,外面一层是维数,里面一层是每一维。但实际上,要做起来很难!

最后决定最外层循环用元素个数,里面配合使用维数的循环,最终解决问题!

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));
});
}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: