C++,关于运算符重载,重载一个矩阵数乘 *
#include<iostream.h>classMAT{int**p;intm,n;public:MAT(intx,inty);MAT(MAT&x){p=x.p;m=x...
#include<iostream.h>
class MAT
{
int **p;
int m,n;
public:
MAT(int x,int y);
MAT(MAT &x)
{
p=x.p;
m=x.m;
n=x.n;
}
void get_element(int i,int j,int value)//输入矩阵
{
p[i][j] = value;
}
int & put_element(int i,int j)//输出矩阵
{
return p[i][j];
}
MAT operator *(int);//矩阵乘一个数的函数
};
MAT::MAT(int x,int y)
{
m = x;
n = y;
p = new int *[m];
for(int i = 0;i<m;i++)
{
p[i] = new int [n];
}
}
MAT MAT::operator *(int k)//矩阵乘一个数的函数定义,这里好像出问题了
{
MAT temp(m,n);
for(int i;i<m;i++)
for(int j;j<n;j++)
{
temp.p[i][j]=p[i][j]*k;
}
return temp;
}
//==============================================================================
int main()
{
int m,n;
int k;
cout<<"enter size of matrix:";
cin>>m>>n;
MAT a(m,n),b(m,n);
cout<<"enter matrix elements row by row \n";
int i,j,value;
for(i=0;i<m;i++)
{
for(j=0;j<n;j++)
{
cin>>value;
a.get_element(i,j,value);
}
}
cout<<"\n"<<endl;
cout<<"multiply :";
cin>>k;
b=a*k;
for(i=0;i<m;i++)
{
for(j=0;j<n;j++)
{
cout<<b.put_element(i,j)<<" ";
}
cout<<endl;
}
return 0;
}
编译无问题 但运行时出错 展开
class MAT
{
int **p;
int m,n;
public:
MAT(int x,int y);
MAT(MAT &x)
{
p=x.p;
m=x.m;
n=x.n;
}
void get_element(int i,int j,int value)//输入矩阵
{
p[i][j] = value;
}
int & put_element(int i,int j)//输出矩阵
{
return p[i][j];
}
MAT operator *(int);//矩阵乘一个数的函数
};
MAT::MAT(int x,int y)
{
m = x;
n = y;
p = new int *[m];
for(int i = 0;i<m;i++)
{
p[i] = new int [n];
}
}
MAT MAT::operator *(int k)//矩阵乘一个数的函数定义,这里好像出问题了
{
MAT temp(m,n);
for(int i;i<m;i++)
for(int j;j<n;j++)
{
temp.p[i][j]=p[i][j]*k;
}
return temp;
}
//==============================================================================
int main()
{
int m,n;
int k;
cout<<"enter size of matrix:";
cin>>m>>n;
MAT a(m,n),b(m,n);
cout<<"enter matrix elements row by row \n";
int i,j,value;
for(i=0;i<m;i++)
{
for(j=0;j<n;j++)
{
cin>>value;
a.get_element(i,j,value);
}
}
cout<<"\n"<<endl;
cout<<"multiply :";
cin>>k;
b=a*k;
for(i=0;i<m;i++)
{
for(j=0;j<n;j++)
{
cout<<b.put_element(i,j)<<" ";
}
cout<<endl;
}
return 0;
}
编译无问题 但运行时出错 展开
2个回答
展开全部
MAT(MAT &x)//赋值构造函数的p也要动态new空间,不然他就和x共享一个p了。MAT MAT::operator *(int k)返回的就是一个他的copy,所以自己改改下面这个函数吧
MAT(MAT &x)
{
p=x.p;
m=x.m;
n=x.n;
}
还有,析构函数要delete前面给p动态分配的空间。。。没看见你的析构呢,再重载=
帮你改了下。。。
#include <iostream>
using namespace std;
class MAT
{
int **p;
int m,n;
public:
MAT(int x,int y);
MAT(MAT &x)
{
m=x.m;
n=x.n;
p = new int *[m];
for(int i = 0;i<m;i++)
{
p[i] = new int [n];
}
for(int i=0;i<m;i++)
for(int j=0;j<n;j++)
{
p[i][j]=x.p[i][j];
}
}
MAT& operator =(MAT &x)
{
if(p!=x.p)
{
if(p)
{
for(int i = 0;i<m;i++)
{
delete [] p[i];
}
delete [] p;
}
m=x.m;
n=x.n;
p = new int *[m];
for(int i = 0;i<m;i++)
{
p[i] = new int [n];
}
for(int i=0;i<m;i++)
for(int j=0;j<n;j++)
{
p[i][j]=x.p[i][j];
}
}
return *this;
}
~MAT()
{
for(int i = 0;i<m;i++)
{
delete [] p[i];
}
delete [] p;
}
void get_element(int i,int j,int value)//输入矩阵
{
p[i][j] = value;
}
int & put_element(int i,int j)//输出矩阵
{
return p[i][j];
}
MAT operator *(int);//矩阵乘一个数的函数
};
MAT::MAT(int x,int y)
{
m = x;
n = y;
p = new int *[m];
for(int i = 0;i<m;i++)
{
p[i] = new int [n];
}
}
MAT MAT::operator *(int k)//矩阵乘一个数的函数定义,这里好像出问题了
{
MAT temp(m,n);
for(int i=0;i<m;i++)
for(int j=0;j<n;j++)
{
temp.p[i][j]=p[i][j]*k;
}
return temp;
}
//==============================================================================
int main()
{
int m,n;
int k;
cout<<"enter size of matrix:";
cin>>m>>n;
MAT a(m,n),b(m,n);
cout<<"enter matrix elements row by row \n";
int i,j,value;
for(i=0;i<m;i++)
{
for(j=0;j<n;j++)
{
cin>>value;
a.get_element(i,j,value);
}
}
cout<<"\n"<<endl;
cout<<"multiply :";
cin>>k;
b=a*k;
for(i=0;i<m;i++)
{
for(j=0;j<n;j++)
{
cout<<b.put_element(i,j)<<" ";
}
cout<<endl;
}
return 0;
}
MAT(MAT &x)
{
p=x.p;
m=x.m;
n=x.n;
}
还有,析构函数要delete前面给p动态分配的空间。。。没看见你的析构呢,再重载=
帮你改了下。。。
#include <iostream>
using namespace std;
class MAT
{
int **p;
int m,n;
public:
MAT(int x,int y);
MAT(MAT &x)
{
m=x.m;
n=x.n;
p = new int *[m];
for(int i = 0;i<m;i++)
{
p[i] = new int [n];
}
for(int i=0;i<m;i++)
for(int j=0;j<n;j++)
{
p[i][j]=x.p[i][j];
}
}
MAT& operator =(MAT &x)
{
if(p!=x.p)
{
if(p)
{
for(int i = 0;i<m;i++)
{
delete [] p[i];
}
delete [] p;
}
m=x.m;
n=x.n;
p = new int *[m];
for(int i = 0;i<m;i++)
{
p[i] = new int [n];
}
for(int i=0;i<m;i++)
for(int j=0;j<n;j++)
{
p[i][j]=x.p[i][j];
}
}
return *this;
}
~MAT()
{
for(int i = 0;i<m;i++)
{
delete [] p[i];
}
delete [] p;
}
void get_element(int i,int j,int value)//输入矩阵
{
p[i][j] = value;
}
int & put_element(int i,int j)//输出矩阵
{
return p[i][j];
}
MAT operator *(int);//矩阵乘一个数的函数
};
MAT::MAT(int x,int y)
{
m = x;
n = y;
p = new int *[m];
for(int i = 0;i<m;i++)
{
p[i] = new int [n];
}
}
MAT MAT::operator *(int k)//矩阵乘一个数的函数定义,这里好像出问题了
{
MAT temp(m,n);
for(int i=0;i<m;i++)
for(int j=0;j<n;j++)
{
temp.p[i][j]=p[i][j]*k;
}
return temp;
}
//==============================================================================
int main()
{
int m,n;
int k;
cout<<"enter size of matrix:";
cin>>m>>n;
MAT a(m,n),b(m,n);
cout<<"enter matrix elements row by row \n";
int i,j,value;
for(i=0;i<m;i++)
{
for(j=0;j<n;j++)
{
cin>>value;
a.get_element(i,j,value);
}
}
cout<<"\n"<<endl;
cout<<"multiply :";
cin>>k;
b=a*k;
for(i=0;i<m;i++)
{
for(j=0;j<n;j++)
{
cout<<b.put_element(i,j)<<" ";
}
cout<<endl;
}
return 0;
}
更多追问追答
追问
不会改哈~
追答
你把我改后的copy下,编译没问题就行。。。
本回答被提问者采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
// ---------------- ---------------------
// ----------------------------------------------------------------
// 假期无聊,实现的矩阵类,模板哦!哈哈。。。
/// ------------- ---------------
/// ---------------------------------------------------
#include <iostream>
#include <vector>
#include <cassert>
using namespace std;
template < class T >
class CMatrix
{
public: //------------------ 构造部 -------------------------
CMatrix( void );
CMatrix( unsigned h, unsigned w );
CMatrix( const CMatrix& m );
CMatrix( const vector<T>& vec );
CMatrix( const vector<T>& vec,unsigned h,unsigned w );
~CMatrix(void);
private: //------------------- 数据部 ---------------------------
vector<T> m_vec_data;
unsigned m_u_width;
unsigned m_u_height;
public: // ------------------- 重载运算符 -------------------------
/// --- 以下均要求T具有如下运算能力:+ - += 等用到的。。。。
//取值运算
T& operator() ( unsigned row, unsigned col );
T operator() ( unsigned row, unsigned col ) const;
//赋值运算
CMatrix& operator = ( const CMatrix& );
CMatrix& operator += ( const CMatrix& );
CMatrix& operator -= ( const CMatrix& );
CMatrix& operator *= ( T );
CMatrix& operator /= ( T );
//二元运算符
CMatrix operator + ( const CMatrix& ) const;
CMatrix operator - ( const CMatrix& ) const;
CMatrix operator * ( const CMatrix& ) const;
CMatrix operator * ( T ) const;
CMatrix operator / ( T ) const;
bool operator == ( const CMatrix& ) const;
bool operator != ( const CMatrix& ) const;
public: // -------------------- 操作函数部 -------------------------
void transpose();
inline bool empty();
inline long size();
inline unsigned height();
inline unsigned width();
public: // ------------------ 输入输出 ----------------------
// 注意:矩阵元素必须支持输入输出,否则程序会错误!!
/*friend ostream& operator << ( ostream& os,const CMatrix& ma );*/
template < typename T > friend ostream& operator << ( ostream& os,const CMatrix<T>& ma );
//friend istream& operator >> ( istream& is,CMatrix& ma );
template < class T > friend istream& operator >> ( istream& is,CMatrix<T>& ma );
};
/**-----------------------------------------------------------------------------
* 输出
*------------------------------------------------------------------------------
*/
template < class T >
ostream& operator << ( ostream& os,const CMatrix<T>& ma )
{
if(!ma.m_u_height || !ma.m_u_width)
{
os<<"这是一个空矩阵!\n";
return os;
}
for(unsigned i=0;i<ma.m_u_height;i++)
{
for(unsigned j=0;j<ma.m_u_width;j++)
{
os<<ma.m_vec_data[i*ma.m_u_width + j]<<"\t";
}
os<<endl<<endl;
}
return os;
}
/**-----------------------------------------------------------------------------
* 输入
*------------------------------------------------------------------------------
*/
template < class T >
istream& operator >> ( istream& is,CMatrix<T>& ma )
{
if( !ma.m_u_height && !ma.m_u_width )
{
cerr<<"空矩阵!\n";
return is;
}
cout<<"请依次输入各个共"<<ma.m_u_height*ma.m_u_width<<"个成员:\n";
for( unsigned i=0;i<ma.m_u_height;i++ )
{
for( unsigned j=0;j<ma.m_u_width;j++ )
{
cout<<"["<<i<<"]["<<j<<"]=";
is>>ma.m_vec_data[i*ma.m_u_width + j];
}
}
return is;
}
/**-----------------------------------------------------------------------------
* 普通构造
*------------------------------------------------------------------------------
*/
template < class T >
CMatrix<T>::CMatrix(void):m_u_width(0),m_u_height(0)
{
}
/**-----------------------------------------------------------------------------
* 构造指定大小的全0矩阵
*------------------------------------------------------------------------------
*/
template < class T >
CMatrix<T>::CMatrix( unsigned h,unsigned w ):m_u_width(w),m_u_height(h)
{
//unsigned size = w*h;
//while(size--)
//{
// m_vec_data.push_back(0);
//}
vector<T> temp(w*h,T());
m_vec_data = temp;
}
/**-----------------------------------------------------------------------------
* 拷贝构造函数
*------------------------------------------------------------------------------
*/
template < class T >
CMatrix<T>::CMatrix( const CMatrix& m ):m_vec_data(m.m_vec_data),m_u_width(m.m_u_width),m_u_height(m.m_u_height)
{
//m_vec_data = m.m_vec_data;
//m_u_width = m.m_u_width;
//m_u_height = m.m_u_height;
}
/**-----------------------------------------------------------------------------
* 以向量构造
*------------------------------------------------------------------------------
*/
template < class T >
CMatrix<T>::CMatrix(const vector<T>& vec):m_u_width(static_cast<unsigned>(vec.size())),m_u_height(1),m_vec_data(vec)
{
//m_u_width = static_cast<unsigned>(vec.size());
//m_u_height = 1;
//m_vec_data = vec;
}
/**-----------------------------------------------------------------------------
* 以向量+大小构造
*------------------------------------------------------------------------------
*/
template < class T >
CMatrix<T>::CMatrix(const vector<T>& vec, unsigned int h, unsigned int w):m_u_height(h),m_u_width(w)
{
// --- 1.0 版 -----
//unsigned input_capability = h * w;
//unsigned fact_capability = static_cast<unsigned>(vec.size());
//if( input_capability == fact_capability )
//{
// m_vec_data = vec;
//}
//else if( input_capability < fact_capability )
//{
// unsigned gap = fact_capability - input_capability;
// vector<T> temp = vec;
// while( gap-- )
// {
// temp.pop_back();
// }
// m_vec_data = vec;
//}
//else
//{
// unsigned gap = input_capability - fact_capability;
// vector<T> temp = vec;
// while( gap-- )
// {
// temp.push_back(0);
// }
// m_vec_data = vec;
//}
// --- 2.0 版 ------
int gap = h*w - static_cast<unsigned>(vec.size());
if( !gap )
{
m_vec_data = vec;
}
else if( gap < 0 )
{
m_vec_data = vec;
m_vec_data.erase( m_vec_data.end() + gap,m_vec_data.end() ); //注意:此时gap为负数,故为+
}
else
{
//注意,此时使用了类型T的默认构造函数
m_vec_data = vec;
m_vec_data.insert(m_vec_data.end(),gap,T());
}
}
/**-----------------------------------------------------------------------------
* 析构函数
*------------------------------------------------------------------------------
*/
template < class T >
CMatrix<T>::~CMatrix(void)
{
m_u_width = 0;
m_u_height = 0;
m_vec_data.clear();
}
/**-----------------------------------------------------------------------------
* 取值
*------------------------------------------------------------------------------
*/
template < class T >
T& CMatrix<T>::operator ()(unsigned int row, unsigned int col)
{
assert( row < m_u_height&&col < m_u_width ); //必须在范围内
return m_vec_data[row*m_u_width + col];
}
/**-----------------------------------------------------------------------------
* const取值
*------------------------------------------------------------------------------
*/
template < class T >
T CMatrix<T>::operator ()(unsigned int row, unsigned int col) const
{
assert( row < m_u_height&&col < m_u_width ); //在范围内
return m_vec_data[row*m_u_width + col];
}
/**-----------------------------------------------------------------------------
* 矩阵=
*------------------------------------------------------------------------------
*/
template < class T >
CMatrix<T>& CMatrix<T>::operator = ( const CMatrix& ma )
{
m_u_width = ma.m_u_width;
m_u_height = ma.m_u_height;
m_vec_data = ma.m_vec_data;
return *this;
}
/**-----------------------------------------------------------------------------
* 矩阵+=
*------------------------------------------------------------------------------
*/
template < class T >
CMatrix<T>& CMatrix<T>::operator += ( const CMatrix& ma )
{
assert( (m_u_height == ma.m_u_height) && (m_u_width == ma.m_u_width) ); //行、列相同
for(unsigned i=0;i<m_vec_data.size();i++)
{
m_vec_data[i] += ma.m_vec_data[i];
}
return *this;
}
/**-----------------------------------------------------------------------------
* 矩阵-=
*------------------------------------------------------------------------------
*/
template < class T >
CMatrix<T>& CMatrix<T>::operator -= ( const CMatrix& ma )
{
assert( (m_u_height == ma.m_u_height) && (m_u_width == ma.m_u_width) ); //行、列相同
for(unsigned i=0;i<m_vec_data.size();i++)
{
m_vec_data[i] -= ma.m_vec_data[i];
}
return *this;
}
/**-----------------------------------------------------------------------------
* 矩阵*=T
*------------------------------------------------------------------------------
*/
template < class T >
CMatrix<T>& CMatrix<T>::operator *= ( T n )
{
for(vector<T>::iterator it = m_vec_data.begin();it!=m_vec_data.end();it++)
{
*it *= n;
}
return *this;
}
/**-----------------------------------------------------------------------------
* 矩阵/=T
*------------------------------------------------------------------------------
*/
template < class T >
CMatrix<T>& CMatrix<T>::operator /= ( T n )
{
assert(n); //非零
for(vector<T>::iterator it = m_vec_data.begin();it!=m_vec_data.end();it++)
{
*it /= n;
}
return *this;
}
/**-----------------------------------------------------------------------------
* 矩阵+
*------------------------------------------------------------------------------
*/
template < class T >
CMatrix<T> CMatrix<T>::operator + ( const CMatrix& ma ) const
{
assert( (m_u_width == ma.m_u_width)&&(m_u_height == ma.m_u_height) );
vector<T> temp( m_u_width * m_u_height );
for(unsigned i=0;i<m_vec_data.size();i++)
{
temp[i] = m_vec_data[i] + ma.m_vec_data[i];
}
return CMatrix(temp,m_u_height,m_u_width);
}
/**-----------------------------------------------------------------------------
* 矩阵-
*------------------------------------------------------------------------------
*/
template < class T >
CMatrix<T> CMatrix<T>::operator - ( const CMatrix& ma ) const
{
assert( (m_u_width == ma.m_u_width)&&(m_u_height == ma.m_u_height) );
vector<T> temp( m_u_width * m_u_height );
for(unsigned i=0;i<m_vec_data.size();i++)
{
temp[i] = m_vec_data[i] - ma.m_vec_data[i];
}
return CMatrix(temp,m_u_height,m_u_width);
}
/**-----------------------------------------------------------------------------
* 矩阵* --==>>>算法待优化 时间复杂度 n^3
*------------------------------------------------------------------------------
*/
template < class T >
CMatrix<T> CMatrix<T>::operator * ( const CMatrix& ma ) const
{
assert( m_u_width == ma.m_u_height );
CMatrix temp( m_u_height, ma.m_u_width );
for(unsigned i=0; i<m_u_height; i++)
{
for(unsigned j=0;j<ma.m_u_width;j++)
{
for( unsigned m=0;m<ma.m_u_width;m++ )
temp(i,j) += m_vec_data[i*m_u_width + m] * ma(m,j);
}
}
return temp;
}
/**-----------------------------------------------------------------------------
* 矩阵*T
*------------------------------------------------------------------------------
*/
template < class T >
CMatrix<T> CMatrix<T>::operator * ( T n ) const
{
vector<T> temp(m_vec_data);
for(vector<T>::iterator it=temp.begin();it!=temp.end();it++)
{
*it *= n;
}
return CMatrix(temp,m_u_height,m_u_width);
}
/**-----------------------------------------------------------------------------
* 矩阵/T
*------------------------------------------------------------------------------
*/
template < class T >
CMatrix<T> CMatrix<T>::operator / ( T n ) const
{
assert(n);
vector<T> temp(m_vec_data);
for(vector<T>::iterator it=temp.begin();it!=temp.end();it++)
{
*it /= n;
}
return CMatrix(temp,m_u_height,m_u_width);
}
/**-----------------------------------------------------------------------------
* 矩阵 ==
*------------------------------------------------------------------------------
*/
template < class T >
bool CMatrix<T>::operator == ( const CMatrix& ma ) const
{
if( m_u_height != ma.m_u_height || m_u_width != ma.m_u_width )
return false;
for(unsigned i=0;i<m_vec_data.size();i++)
{
if( m_vec_data[i] != ma.m_vec_data[i] )
return false;
}
return true;
}
/**-----------------------------------------------------------------------------
* 矩阵 !=
*------------------------------------------------------------------------------
*/
template < class T >
bool CMatrix<T>::operator !=(const CMatrix& ma) const
{
if(m_u_height != ma.m_u_height || m_u_width != ma.m_u_width)
return false;
for(unsigned i=0;i<m_vec_data.size();i++)
{
if( m_vec_data[i] != ma.m_vec_data[i] )
return true;
}
return false;
}
/**-----------------------------------------------------------------------------
* 矩阵转置
*------------------------------------------------------------------------------
*/
template < class T >
void CMatrix<T>::transpose()
{
vector<T> temp(m_u_width*m_u_height);
for(unsigned i=0;i < m_u_height;i++)
{
for(unsigned j=0;j<m_u_width;j++)
{
temp[ j*m_u_height + i ] = m_vec_data[ i*m_u_width + j ];
}
}
swap(m_u_width,m_u_height);
m_vec_data = temp;
}
/**-----------------------------------------------------------------------------
* 判空
*------------------------------------------------------------------------------
*/
template < class T >
inline bool CMatrix<T>::empty()
{
return m_vec_data.empty();
}
/**-----------------------------------------------------------------------------
* 大小
*------------------------------------------------------------------------------
*/
template < class T >
inline long CMatrix<T>::size()
{
return static_cast<long>(m_vec_data.size());
}
/**-----------------------------------------------------------------------------
* 高度
*------------------------------------------------------------------------------
*/
template < class T >
inline unsigned CMatrix<T>::height()
{
return m_u_height;
}
/**-----------------------------------------------------------------------------
* 宽度
*------------------------------------------------------------------------------
*/
template < class T >
inline unsigned CMatrix<T>::width()
{
return m_u_width;
}
int main()
{
CMatrix<int> mat0(6,8);
cout<<mat0<<endl;
for(int i=0;i<6;i++)
{
for(int j=0;j<8;j++)
mat0(i,j) = i+j;
}
cout<<mat0<<endl;
vector<int> vec( 23,2 );
CMatrix<int> mat1(vec,5,5);
cout<<mat1<<endl;
vector<int> vec1( 40,5);
CMatrix<int> mat2(vec1,6,6);
cout<<mat2<<endl;
CMatrix<int> mat3(6,6);
for(int i=0;i<6;i++)
{
for(int j=0;j<6;j++)
mat3(i,j) = i*j;
}
cout<<mat3<<endl;
cout<<mat3 + mat2<<endl;
mat3 += mat2;
mat3 = mat3 + mat2;
cout<<mat3<<endl;
return 0;
}
追问
我复制下来 编译通过不了哈 有些我还看不懂 不过看起来很值得参考 谢谢哈
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询