@好好zhang先生
关于C#二维数组的处理自己查找资料发现跟自己的项目需要不匹配。
做LED分拣项目过程中遇到这样一个问题,需要将芯片预扫描的二维数组中的所有(0,0)数据删除并改变数组的读,通俗地讲就是比如Arrya[10,2]数组,10行2列数据,假设数组中有5个(0,0)数据;则需要将5个数据删除并吧原来的数据按原来顺序排序并生成一个Arryc[5,2]长度的数组。
下面把自己的思路总结如下:
首先,最初的已知长度的Arrya[10,2]数组中(0,0)分布是随机的,自己假设奇数索引为(0,0),偶数索引为非(0,0)
然后通过Arryb[10,2]数判断Arrya数组中的非0数据,并接受,剩下的位置暂时空缺,并计算出非0数据的个数j
通过计算出的j值重新定义一个长度为j的数组Arryc[j,2]并把Arryb数组中非0数据传入Arryc[j,2],这样就达到了目的
原数组Arrya[10,2]
中间数组Arryb[10,2]
负责将原数组Arrya[10,2]中的非0 数据接收,假设接收了5个,则剩下的位置还是初始化时的值,都为(0,0)
最终数组Arryc[j,2],通过上一步的计算,j=5,则定义Arryc长度为5
至此,便完成了需要的功能
下面展示 源代码片段
。
static void Main(string[] args)
{
//定义一个长度为10的数组Arrya, 偶数索引为0,奇数索引为非0
int ArryLength = 10;//数组长度
int[,] Arrya = new int[ArryLength, 2];
Console.WriteLine("********* Arrya数组 ****************");
for (int i = 0; i < ArryLength; i++)
{
if(i%2==0)
{
Arrya[i, 0] = i ;
Arrya[i, 1] = i+1;
}
else
{
Arrya[i, 0] = 0;
Arrya[i, 1] = 0;
}
Console.Write("第{0}行: ", i);
Console.Write(Arrya[i,0] + ",");
Console.Write(Arrya[i,1]);
Console.WriteLine("\n");//换行输出Arryb
}
//定义一个数组Arryb,将Arrya中不为0的数据按顺序接收并计算为(0,0)的个数
int j = 0 ;
int[,] Arryb = new int[ArryLength, 2];
Console.WriteLine("********* Arryb数组 ****************");
for (int i = 0; i < ArryLength; i++)
{
if (Arrya[i,0] != 0 || Arrya[i,1]!= 0)
{
j = j + 1;
Arryb[j - 1, 0] = Arrya[i, 0];
Arryb[j - 1, 1] = Arrya[i, 1];
}
}
for (int i = 0; i < ArryLength; i++)
{
Console.Write("第{0}行: ", i);
Console.Write(Arryb[i, 0] + ",");
Console.Write(Arryb[i, 1]);
Console.WriteLine("\n");
}
Console.WriteLine("Arrya数组的(0,0)位置是{0}: ", j);
//通过以上的计算Arrya中不为0 的个数j个,定义长度为j的数组
int[,] Arryc = new int[j, 2];
Console.WriteLine("********* Arryc数组 ****************");
for (int i = 0; i < j; i++)
{
Arryc[i, 0] = Arryb[i, 0];
Arryc[i, 1] = Arryb[i, 1];
Console.Write("第{0}行: " , i);
Console.Write(Arryc[i, 0] + ",");
Console.Write(Arryc[i, 1]);
Console.WriteLine("\n");//换行
}
Console.WriteLine("Arryc数组的长度是{0}: ", j);
Console.ReadKey();
}
}