如何遍历维数和各维上限未定的多维数组
生活随笔
收集整理的這篇文章主要介紹了
如何遍历维数和各维上限未定的多维数组
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
這個題目,不方便使用遞歸!
直覺告訴我,可以用兩層遍歷,外面一層是維數,里面一層是每一維。但實際上,要做起來很難!
最后決定最外層循環用元素個數,里面配合使用維數的循環,最終解決問題!
?
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));}); } 我不相信神話,我只相信汗水!我不相信命運,我只相信雙手! 分類: C#本文轉自大石頭博客園博客,原文鏈接:http://www.cnblogs.com/nnhy/archive/2011/05/18/2050004.html,如需轉載請自行聯系原作者
總結
以上是生活随笔為你收集整理的如何遍历维数和各维上限未定的多维数组的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 用df命令显示磁盘使用量和占用率。
- 下一篇: JDK8下载|JDK1.8下载可选择wi