输出矩阵的问题?
#include<iostream>
using namespace std;
class JUZ
{
public:
JUZ();
~JUZ();
void InitJUZ (void);
void OutPJUZ (void);
void AddJUZ (void);
void QFJUZ (int n);
void CSL (void);
private:
int a;
int b;
int **p;
};
JUZ::JUZ()
{
cout<<"请输入需要的矩阵行列"<<endl;
cin>>a>>b;
p = new int *[a];
for(int c=0; c<a; c++)
p[c] = new int [b];
}
JUZ::~JUZ()
{
for(int d=0; d<a; d++)
delete [] (*(p+d));
delete [] p;
}
void JUZ::InitJUZ (void)
{
cout<<"请输入矩阵的个数"<<endl;
for(int e=0; e<a-1; e++)
{
for(int f=0; f<b-1; f++)
cin>>p[e][f];
cout<<endl;
}
for(int g=0; g<b-1; g++)
p[a-1][g]=0;
for(int h=0; h<a; h++)
p[h][b-1]=0;
}
void JUZ::OutPJUZ(void)
{
for(int i=0; i<a; i++)
{
for(int j=0; j<b; j++)
cout<<p[i][j]<<" ";
cout<<endl;
}
}
void JUZ::AddJUZ (void)//这算矩阵的行和列的和不知道错在哪里?
{
for(int k=0; k<a-1; k++)
{
for(int l=0; l<b-1; l++)
p[k][b-1] += p[k][l];
}
for(int m=0; m<b-1; m++)//如果把这函数去掉能正确输出相加行。
{
for(int n=0; n<a-1; n++)
p[m][a-1] += p[n][m];
}
}
void JUZ::QFJUZ (int n)
{
cout<<"把第"<<n<<"列取反"<<endl;
for(int z=0; z<a-1; z++)
p[z][n-1] = -p[z][n-1];
}
void JUZ::CSL(void)
{
for(int aa=0; aa<b-1; aa++)
p[a-1][aa]=0;
for(int bb=0; bb<a; bb++)
p[bb][b-1]=0;
}
int main(void)
{
JUZ juz;
int a;
juz.InitJUZ();
juz.OutPJUZ();
juz.AddJUZ();
juz.OutPJUZ();
cout<<"请输入要取反的列n"<<endl;
cin>>a;
juz.CSL();
juz.QFJUZ(a);
juz.AddJUZ();
juz.OutPJUZ();
return 0;
}
哪位说下咯先谢达。