2
我有下面的C#代码:矩阵C#替换值
int[,] mt = { { 5, 4, 6, 2 }, { 8, 1, 5, 4 }, { 2, 3, 8, 6 }, { 9, 6, 1, 8 } };
int i, min, index, j, v;
for (i = 0; i < mt.GetLength(1); i++)
{
index = 0;
min = int.MaxValue;
for (j = 0; j < mt.GetLength(0); j++)
{
v = mt[j, i];
if (v < min)
{ min = mt[j, i]; index = j; }
}
mt[i, index] = mt[i, i]; mt[i, i] = min;
}
for (i = 0; i < mt.GetLength(0); i++)
{//print the matrix after changes
for (j = 0; j < mt.GetLength(1); j++)
Console.Write("{0,3}", mt[i, j]);
Console.WriteLine();
}
Console.ReadLine();
这段代码应该做的是用值来代替每个山坳的最低值,在主对角线的同山坳至极部分(这是二次矩阵)。
因此,col中minmial值的单元格在同一列中的主对角线上获取单元格的值,并且主对角线上的单元格获得同一列中最小数目的单元格的值。
我想上面的代码,但我得到这样的结果:
{ { 2, 4, 5, 2 }, { 4, 1, 3, 6 }, { 5, 5, 1, 1 }, { 2, 4, 8, 2 } };
这是我应该得到:
{ { 2, 4, 6, 8 }, { 8, 1, 5, 4 }, { 2, 3, 1, 8 }, { 8, 6, 1, 2 } };
我的问题是什么,我应该更改代码以获得无聊的结果?
希望得到帮助,谢谢!
您好,感谢你这么多,我这样做了愚蠢的错误!再次感谢! –