知识大全 c#简单实现二维数组和二维数组列表List<>的转置
Posted 知
篇首语:书卷多情似故人,晨昏忧乐每相亲。本文由小常识网(cha138.com)小编为大家整理,主要介绍了知识大全 c#简单实现二维数组和二维数组列表List<>的转置相关的知识,希望对你有一定的参考价值。
c#简单实现二维数组和二维数组列表List<>的转置 以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧!
刚看到网上一篇博文里用sql实现了行列转置 sql server / 只用一个pivot函数就可以实现sql server 很多行的复杂实现 提到转置 立刻想起还在求学阶段曾经做过的一个练习 用c语言实现二维数组的转置 相信大家都做过这个练习 下面利用c#利器也实现一遍 没有实际意义 练练手而已
二维数组转置
Code
class Program
public static string[ ] Rotate(string[ ] array)
int x = array GetUpperBound( ); //一维
int y = array GetUpperBound( ); //二维
string[ ] newArray = new string[y + x + ]; //构造转置二维数组
for (int i = ; i <= x; i++)
for (int j = ; j <= y; j++)
newArray[j i] = array[i j];
return newArray;
static void Main(string[] args)
string[ ] array = new string[ ];
for (int i = ; i < ; i++)
for (int j = ; j < ; j++)
array[i j] = i ToString() + j ToString();
//显示原数组
Console WriteLine( Source Array: );
for (int i = ; i < ; i++)
string soureResult = string Empty;
for (int j = ; j < ; j++)
soureResult += array[i j] + ;
Console WriteLine(soureResult);
string[ ] newArray = Rotate(array);
//显示转置后的数组
Console WriteLine( Destiney Array: );
for (int i = ; i < ; i++)
string dstResult = string Empty;
for (int j = ; j < ; j++)
dstResult += newArray[i j] + ;
Console WriteLine(dstResult);
Console ReadLine();
二维数组列表List<>的转置
这个是想到在实际项目中操作集合经常用到泛型List 顺便实现一下它的转置 思路很简单 根据 我们已经实现了转置 所以就要想方设法把泛型List转换成二维数组 然后转置 接着将转换后的数组再转换成泛型List 呵呵 笔者偷懒惯了 其实应该还有其他的方法 不管了 先实现看下效果
Code
class Program
/// <summary>
/// 二维数组转置函数
/// </summary>
/// <param name= array ></param>
/// <returns></returns>
public static string[ ] Rotate(string[ ] array)
int x = array GetUpperBound( ); //一维
int y = array GetUpperBound( ); //二维
string[ ] newArray = new string[y + x + ]; //构造转置二维数组
for (int i = ; i <= x; i++)
for (int j = ; j <= y; j++)
newArray[j i] = array[i j];
return newArray;
/// <summary>
/// 将二维列表(List)转换成二维数组 二维数组转置 然后将二维数组转换成列表
/// </summary>
/// <param name= original ></param>
/// <returns></returns>
public static List<List<string>> Rotate(List<List<string>> original)
List<string>[] array = original ToArray();
List<List<string>> lists = new List<List<string>>();
if (array Length== )
throw new IndexOutOfRangeException( Index OutOf Range );
int x = array[ ] Count;
int y = original Count;
//将列表抓换成数组
string[ ] oArray = new string[y x];
for (int i = ; i < y; i++)
int j = ;
foreach (string s in array[i])
oArray[i j] = s;
j++;
string[ ] newTwoArray = new string[x y];
newTwoArray = Rotate(oArray);//转置
//二维数组转换成二维List集合
for (int i = ; i < x; i++)
List<string> list = new List<string>();
for (int j = ; j < y; j++)
list Add(newTwoArray[i j]);
lists Add(list);
return lists;
static void Main(string[] args)
List<List<string>> sourceList = new List<List<string>>(); //测试的二维List
for (int i = ; i < ; i++)
List<string> list = new List<string>();
for (int j = ; j < ; j++)
list Add(i ToString() + j ToString());
sourceList Add(list);
//显示原列表
Console WriteLine( Source List: );
for (int i = ; i < sourceList Count; i++)
string soureResult = string Empty;
for (int j = ; j < sourceList[i] Count; j++)
soureResult += sourceList[i][j] + ;
Console WriteLine(soureResult);
List<List<string>> dstList = Rotate(sourceList);
//显示转置后的列表
Console WriteLine( Destiney List: );
for (int i = ; i < dstList Count; i++)
string dstResult = string Empty;
for (int j = ; j < dstList[i] Count; j++)
dstResult += dstList[i][j] + ;
Console WriteLine(dstResult);
Console ReadLine();
cha138/Article/program/net/201311/11311
相关参考
矩阵是科学与工程计算问题中常用的数学对象之一 矩阵的存储 矩阵的二维数组描述 矩阵用二维数组描述时存储的密度为可以对其元素进行随机存取各种矩阵运算也非常简单 矩阵的压缩存储 矩阵中非零元
矩阵是科学与工程计算问题中常用的数学对象之一矩阵的存储矩阵的二维数组描述 矩阵用二维数组描述时存储的密度为可以对其元素进行随机存取各种矩阵运算也非常简单cha138/Article/p
知识大全 数据结构考研分类复习真题 第五章 数组和广义表[5]
设二维数组A[mn](即m行n列)按行存储在数组B[m*n]中则二维数组元素A[ij]在一维数组B中的下标为( )【南京理工大学一(分)】 A(i)*n+j&n
数组的定义 数组(Arrays)是由一组类型相同的数据元素构造而成的它的每个元素由一个值和一组下标确定 二维数组Ann…nm的每个元素aii…im都属于m个向量最多可以有m
知识大全 php函数range() round()和list()如何使用
一>> range()函数快速创建数组的简单方法使用low到high范围的整数值填充数组函数将返回一个包含次范围内所有整数的数组形式如下 arrayrange(intlowinth
知识大全 数据结构考研分类复习真题 第五章 数组和广义表[42]
设二维数组a[mn]含有m*n个整数 ()写出算法(pascal过程或c函数)判断a中所有元素是否互不相同?输出相关信息(yes/no) ()试分析算法的时间复杂度【华中理工大学五(分)】
知识大全 数据结构考研分类复习真题 第五章 数组和广义表[24]
已知A为稀疏矩阵试从空间和时间角度比较采用两种不同的存储结构(二维数组和三元组表)完成求运算的优缺点【西安电子科技大学二(分)】 特殊矩阵和稀疏矩阵哪一种压缩存储后失去随机存取的功能?为什么?【
知识大全 数据结构考研分类复习真题 第五章 数组和广义表[10]
设二维数组A[]每个元素占有个存储单元存储起始地址为如按行优先顺序存储则元素A[]的存储地址为__()___如按列优先顺序存储则元素A[]的存储地址为__()___【北方交通大学二(分)】 设数
知识大全 数据结构考研分类复习真题 第五章 数组和广义表[18]
完善下列程序每小题在PASCAL语言(a)和C语言(b)中任选一题下面的程序将数列…n*n依次按蛇型方式存放在二维数组A[nn]中即(示意图编者略) (a)算法的PASCAL语言程序描述(编者略
知识大全 数据结构考研分类复习真题 第五章 数组和广义表[4]
二维数组A的每个元素是由个字符组成的串其行下标i=…列下标j=…若A按行先存储元素A[]的起始地址与当A按列先存储时的元素( )的起始地址相同设每个字符占一个字节