2013-05-26 129 views
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 } }; 

我的问题是什么,我应该更改代码以获得无聊的结果?

希望得到帮助,谢谢!

回答

7

你应该写:代替

mt[index, i] = mt[i, i]; 

mt[i, index] = mt[i, i]; 
+0

您好,感谢你这么多,我这样做了愚蠢的错误!再次感谢! –