這是樓主的代碼
`#include
#define M 3
#define N 4
class Matrix
{
int a[3][4];
public:
Matrix(int b[M][N])
{
int i,j;
for(i=0;i<M;i++)
for(j=0;j<N;j++)
a[i][j]=b[i][j];
}
void process();
void show()
{
int i,j;
for(i=0;i<M;i++)
{
for(j=0;j<N;j++)
cout<<a[i][j]<<'\t';
cout<<endl;
}
}
};
void Matrix::process()
{
int max,min;
int i,j,maxi,maxj,mini,minj;
max=min=a[0][0];
for(i=0;i
for(j=0;j
{
if(max
{
max=a[i][j];
maxi=i;
maxj=j;
}
if(min>a[i][j])
{
min=a[i][j];
mini=i;
minj=j;
}
}
int t;
t=a[0][0];a[0][0]=a[maxi][maxj];a[maxi][maxj]=t;
t=a[M-1][N-1];a[M-1][N-1]=a[maxi][maxj];a[maxi][maxj]=t;
}
int main()
{int b[M][N]={{1,4,5,6},{7,2,10,11},{8,9,12,3}};
Matrix ma(b);
ma.process();
ma.show();
return 0;
}
在這裡書寫代碼片
樓主不太明白這段代碼t=a[M-1][N-1];a[M-1][N-1]=a[maxi][maxj];a[maxi][maxj]=t;(將最小值換至數組右下角)於是將數組中1和4的位置換了下,結果如圖
結果明顯不對,然後樓主將maxi,maxj換成了mini,minj,結果便正確了,但但樓主將1
4變成原位置時代碼又錯誤了,這該怎麼辦?
這不就是找到最大的放在左上,最小的放在右下嗎,你試試把min初始化改成min=a[M-1][N-1]試試,就是你的代碼有些地方被吞掉了