C#实现对二维数组排序的方法
更新时间:2015年06月17日 17:47:48 作者:红薯
这篇文章主要介绍了C#实现对二维数组排序的方法,实例分析了C#数组遍历与排序的相关技巧,需要的朋友可以参考下
本文实例讲述了C#实现对二维数组排序的方法。分享给大家供大家参考。具体实现方法如下:
/// <summary> /// A generic routine to sort a two dimensional array of a specified type based on the specified column. /// </summary> /// <param name="array">The array to sort.</param> /// <param name="sortCol">The index of the column to sort.</param> /// <param name="order">Specify "DESC" or "DESCENDING" for a descending sort otherwise /// leave blank or specify "ASC" or "ASCENDING".</param> /// <remarks>The original array is sorted in place.</remarks> /// <see cref="http://stackoverflow.com/questions/232395/how-do-i-sort-a-two-dimensional-array-in-c"/> private static void Sort<T>(T[,] array, int sortCol, string order) { int colCount = array.GetLength(1), rowCount = array.GetLength(0); if (sortCol >= colCount || sortCol < 0) throw new System.ArgumentOutOfRangeException("sortCol", "The column to sort on must be contained within the array bounds."); DataTable dt = new DataTable(); // Name the columns with the second dimension index values, e.g., "0", "1", etc. for (int col = 0; col < colCount; col++) { DataColumn dc = new DataColumn(col.ToString(), typeof(T)); dt.Columns.Add(dc); } // Load data into the data table: for (int rowindex = 0; rowindex < rowCount; rowindex++) { DataRow rowData = dt.NewRow(); for (int col = 0; col < colCount; col++) rowData[col] = array[rowindex, col]; dt.Rows.Add(rowData); } // Sort by using the column index = name + an optional order: DataRow[] rows = dt.Select("", sortCol.ToString() + " " + order); for (int row = 0; row <= rows.GetUpperBound(0); row++) { DataRow dr = rows[row]; for (int col = 0; col < colCount; col++) { array[row, col] = (T)dr[col]; } } dt.Dispose(); }
希望本文所述对大家的C#程序设计有所帮助。
相关文章
C# Dictionary和SortedDictionary的简介
今天小编就为大家分享一篇关于C# Dictionary和SortedDictionary的简介,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看吧2018-10-10C#使用struct类型作为泛型Dictionary<TKey,TValue>的键
这篇文章介绍了C#使用struct类型作为泛型Dictionary<TKey,TValue>键值的方法,文中通过示例代码介绍的非常详细。对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下2022-08-08
最新评论