青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

華劍緣
一切都在這個過程中獲得,將那些目標埋藏于心中
posts - 19,comments - 20,trackbacks - 0
[求助]?關于拷貝構造函數,對象傳遞!!

#include?
< iostream.h >
class ?Matrix
{
private :
????
int ?rows,columns;
public :
????????
int ? ** pMatrix;
???Matrix(?
int ?rows, int ?columns);
???Matrix(Matrix
& ?);
???
~ Matrix();
int ?GetRows();
int ?GetColumns();
void ?SetValue();
void ?Mul(Matrix?a,Matrix?b);
void ?Mul(Matrix? * pa,Matrix? * pb);
void ?Mul(Matrix? & a,Matrix? & b);

}
;

int ?Matrix::GetRows() { return ?rows;} ;
int ?Matrix::GetColumns() { return ?columns;} ;

// 構造函數
Matrix::Matrix( int ?x, int ?y)
{
?????rows
= x;
?????????columns
= y;
????????pMatrix
= new ? int * ?[x];
?????
for ( int ?i = 0 ;?i < x;?i ++ )
?????pMatrix[i]
= new ? int ?[y];
}


// 析構函數
Matrix:: ~ Matrix()
{
????????
for ( int ?i = 0 ;i < rows;i ++ )
??????????delete[]?pMatrix[i];
????delete[]?pMatrix;
}


// 賦值函數
void ?Matrix::SetValue()
{
????
int ?i,j,value;
????
for (?i = 0 ;?i < rows;?i ++ )
??????
{
???????????
for (?j = 0 ;?j < columns;?j ++ )
?????????
{
????????????????cout
<< " " << i << " " ;
????????cout
<< " " << j << " 列: " ;
????????cin
>> value;
????????cout
<< endl;
????????pMatrix[i][j]
= value;
?????????}

???????}

}


// 拷貝構造函數
Matrix::Matrix(Matrix & ?M)
{??
?????
for ( int ?i = 0 ;?i < M.rows;?i ++ )
?????????????????
for ( int ?j = 0 ;?j < M.columns;?j ++ )
???????????????????pMatrix[i][j]
= M.pMatrix[i][j];????? /// //這里對不對?有什么更好的方式?
}


void ?Matrix::Mul(Matrix?a,Matrix?b)
{
??Matrix?c(a.GetRows(),b.GetColumns());
????
for ( int ?i = 0 ;i < a.GetRows();i ++ ) {
????????????????
for ( int ?y = 0 ;y < b.GetColumns();y ++ ) {
??????????
if ?(a.GetColumns() == b.GetRows())
????????????
for ( int ?j = 0 ,x = 0 ;j < a.GetColumns(),x < b.GetRows?();j ++ ,x ++ )
??????????????????c.pMatrix[i][y]?
+= a.pMatrix[i][j] * b.pMatrix[x][y];???? /// //這里對不對?有什么更好的方式?

???????????
else ? break ;
????????????????????????
????????????????}

????????}

???
}


// 主函數
void ?main()
{
????????Matrix?Ma(
3 , 2 ),Mb( 2 , 2 );
????????Ma.SetValue();
????????Mb.SetValue();
????
for ( int ?i;i < Ma.GetRows();i ++ )
????????????????
for ( int ?j;j < Ma.GetColumns();j ++ )
????????????????????????cout
<< Ma.pMatrix[i][j];?? // 為什么編譯運行后不能輸出呢??

????????Matrix?Mc(
3 , 2 );??? /// 覺得這樣不妥,還有什么跟好的方法么
????????Mc.Mul(Ma,Mb);???? /// 這樣也不對,怎么讓兩個Matrix對象相乘呢,有什么更好的方式么?
}


感謝大家熱心指教。
一下是整理后的。
/////////////////////////////////////////////////
/////////////////////////////////////////////////

///////////////////Matrix.Class////////////////////////

#include?<iostream.h>
//using?namespace?std;???????//為什么不能在VC下正常使用

class?Matrix
{
private:
????
int?**pMatrix;
????
int?rows,columns;
public:
static?int?ObjectAliveNo;
????Matrix(
int?rows=0,int?columns=0);
????Matrix(
const?Matrix?&M);
????
~Matrix();
Matrix
&?operator=(const?Matrix&?M);
int?GetRows()?const;
int?GetColumns()?const;
int?GetObjNo()?const;
void?SetValue();
void?Mul(const?Matrix?a,const?Matrix?b);
void?Mul(const?Matrix?*pa,const?Matrix?*pb);
void?MUl(const?Matrix?&a,const?Matrix?&b);
friend?Matrix?
operator~(Matrix&?a);?????????????????????????????????//重載"~"操作符實現矩陣轉置
friend?Matrix?operator*(const?Matrix&?a,const?Matrix&?b);??????????//重載"~"操作符實現矩陣相乘
//friend?ostream&?operator<<(const?ostream&?os,const?Matrix&?M);???//!!!
friend?ostream&?operator<<(ostream&?os,const?Matrix&?M);
}
;

//構造函數
Matrix::Matrix(int?x,int?y)
{
????ObjectAliveNo
++;
????rows
=x;
????columns
=y;
??????pMatrix
=new?int?*[rows];????????//創建指針數組
??????for(int?i=0;?i<rows;?i++){
???????pMatrix[i]
=new?int?[columns];?//真正實現二維數組
???????for(int?j=0;?j<columns;?j++)
?????????pMatrix[i][j]
=0;???????????//對二維數組初始化
?????}

}


//拷貝構造函數函數
Matrix::Matrix(const?Matrix&?M)
{
????rows
=M.rows;
????columns
=M.columns;
????
//賦值前現分配空間!
????pMatrix=new?int?*[rows];
?????
for(int?m=0;?m<rows;?m++)
???????pMatrix[m]
=new?int?[columns];
???????
??
for(int?i=0;i<rows;i++)
????
for(int?j=0;j<columns;j++)
??????pMatrix[i][j]
=M.pMatrix[i][j];
}


//析構函數
Matrix::~Matrix()
{
????ObjectAliveNo
--;
????
for(int?i=0;i<rows;i++)
????delete[]?pMatrix[i];????????
//注意delete的順序
????delete[]?pMatrix;
}


//
int?Matrix::GetRows()?const?{return?rows;}????????????//
int?Matrix::GetColumns()?const?{return?columns;}??????//
int?Matrix::GetObjNo()?const?{return?ObjectAliveNo;}??//對象數


//為矩陣賦值
void?Matrix::SetValue()
{
??cout
<<"請對矩陣的每一項賦值:"<<endl;
????
int?i,j,value;
????
for(i=0;i<rows;i++)
??????
for(j=0;j<columns;j++){
????????cout
<<"第?"<<i+1<<"";
????????cout
<<""<<j+1<<"列:";
????????cin
>>value;
????????pMatrix[i][j]
=value;
??????}

}


//重載"="操作符實現矩陣之間賦值
Matrix&?Matrix::operator=(const?Matrix&?M)
{
?????
if(this?!=?&M){
????
for?(int?ii?=?0?;ii?<?rows;ii++?)
??????
if(pMatrix[ii])
??????delete[]?pMatrix[ii];
???
if(pMatrix)
???delete[]?pMatrix;
???rows?
=?M.rows;
???columns?
=?M.columns;
??
//分配存儲空間
???pMatrix?=?new?int*?[rows];
???
for?(int?k=0?;k<rows?;k++?)
???pMatrix[k]?
=?new?int[columns];

???
for?(?int?i=0;?i<rows;?i++?)
?????
for?(?int?j?=?0?;?j?<?columns;?j?++?)
??????pMatrix[i][j]?
=?M.pMatrix[i][j];
?}

return?*this;
}


//調用函數實現矩陣相乘操作
void?Matrix::Mul(const?Matrix?a,const?Matrix?b)
{
????Matrix?c(a.GetRows(),b.GetColumns());
????
if(a.GetColumns()==b.GetRows()){
???????
int?temp=0;
???????
for(int?i=0;i<a.GetRows();i++)
???????????
for(int?j=0;j<b.GetColumns();j++){
??????????????
for(int?k=0;k<a.GetColumns();k++)
??????????????temp
=temp+a.pMatrix[i][k]*b.pMatrix[k][j];
??????????????c.pMatrix[i][j]
=temp;
??????????????temp
=0;
???????????}

????}

//輸出相乘結果
?????for(int?i=0;i<c.GetRows();i++){
????cout
<<'\n';
????????
for(int?y=0;y<c.GetColumns();y++)
??????????????cout
<<c.pMatrix[i][y]<<'?';
????????}

}


//重載操作符"*"實現矩陣相乘操作
Matrix?operator*(const?Matrix&?a,const?Matrix&?b)
{
if?(a.columns?==?b.rows){
??Matrix?c(a.rows,b.columns);
???
for?(?int?i?=?0?;i?<?a.rows;i?++?){
????
for?(?int?j?=?0?;j?<?b.columns;j?++?){
???????
for?(?int?columnIndex=?0?;columnIndex?<?a.columns;columnIndex++?)
?????????c.pMatrix[i][j]?
+=?a.pMatrix[i][columnIndex]?*?b.pMatrix[columnIndex][j];
???????}

????}

????
return?c;
??}

else
return?Matrix();
}


//重載"~"操作符實現矩陣轉置
Matrix?operator~(Matrix&?a)
{
????Matrix?b(a.columns,a.rows);
????
for(int?i=0;i<a.rows;i++)
?????
for(int?j=0;j<a.columns;j++)
??????b.pMatrix[j][i]
=a.pMatrix[i][j];
??????
??????
return?b;
}



//對"cout"進行重定義
ostream&?operator<<(ostream&?os,const?Matrix&?M){
??
for?(int?i?=?0;i?<?M.rows;i++?){
?????
for?(int?j?=?0;j?<?M.columns;j++?)
???????os?
<<?M.pMatrix[i][j]?<<?"?";
???????os?
<<?endl;
??}

?
return?(os?<<?endl);
}


//靜態成員賦初值!
int?Matrix::ObjectAliveNo=0;

//主函數
int?main()
{
????Matrix?Ma(
6,3),Mb(3,5);
????Ma.SetValue();
????Mb.SetValue();
cout
<<'\n'<<"現在有"<<Ma.GetObjNo()<<"個矩陣"<<endl;?????//前后對比檢查各種函數對ObjectAliveNo的影響
cout<<Ma<<endl;
Matrix?Mc;
Mc
=Ma*Mb;
cout
<<Mc;
cout
<<'\n'<<"現在有"<<Ma.GetObjNo()<<"個矩陣"<<endl;?????//見上一條注釋?!!出現錯誤:沒有正常計數

cout
<<"Ma的轉置:"<<endl;
Matrix?Me;
Me
=~Ma;
cout
<<Me<<endl;

Matrix?Md;
Md.Mul(Ma,Mb);
cout
<<'\n'<<"現在有"<<Ma.GetObjNo()<<"個矩陣"<<endl;????//有沒有正常計數?


return?0;
}

posted on 2006-04-11 13:22 華劍緣 閱讀(750) 評論(6)  編輯 收藏 引用

FeedBack:
# re: [求助] 關于拷貝構造函數,對象傳遞!!
2006-04-11 15:01 | 芋頭
1、構造函數里沒有對pMatrix初始化為0值,將導致后面有些地方錯誤。
2、拷貝構造函數和默認構造函數只會調用一個,你的拷貝構造函數中沒有初始化pMatrix以及rows和columns。
3、Matrix::Mul中,if可以寫在外面;由于構造函數中沒有初始化0,c.pMatrix[i][y] +=這里肯定是錯誤的;另外,既然a.GetColumns() == b.GetRows(),就沒有必要用j和x這2個變量了,一個就行了。
4、main函數里面的2個for循環,怎么i和j都不用初始化0的嗎?
5、最后2行,是很不妥。可以考慮寫成static,或寫一個全局的operator*。

暫時只看出來這些。至于對錯,這個最好自己調試。可以把算法轉成自己看得懂的語言輸出出來,比如:把矩陣a的第幾行第幾列和矩陣b的第幾行第幾列相乘,加到矩陣c的第幾行第幾列。這樣的話,自己看得懂能排錯就行了。  回復  更多評論
  
# re: [求助] 關于拷貝構造函數,對象傳遞!!
2006-04-11 16:05 | 任我行
void Matrix::Mul(Matrix a,Matrix b)給誰用呢?
  回復  更多評論
  
# re: [求助] 關于拷貝構造函數,對象傳遞!!
2006-04-12 13:44 | 史傳紅
看到了樓主的這篇文章,我試著改了一下,如下:希望大家一起加入討論。

#include <iostream>
using namespace std;

class Matrix
{
private:
int rows,columns;
int **pMatrix;
public:
Matrix(int rows = 3,int columns = 2);
Matrix(const Matrix &M);
~Matrix();
Matrix& operator=(const Matrix& M);
int GetRows() const;
int GetColumns() const;
void SetValue();
friend Matrix operator*(const Matrix& a,const Matrix& b);
friend ostream& operator<<(ostream& os,const Matrix& M);
};

int Matrix::GetRows() const { return rows;}
int Matrix::GetColumns() const { return columns;}

// 構造函數
Matrix::Matrix(int x,int y)
{
rows = x;
columns = y;
//有的時候為了考慮創建對象的效率,在使用的時候分配存儲空間,而不在構造函數中分配
pMatrix = new int* [x];
for (int i = 0 ; i < x; i++ )
{
pMatrix[i] = new int[y];
for(int j = 0;j < y;j++) //初始化每個值為0
pMatrix[i][j] = 0;
}
}
// 析構函數
Matrix::~Matrix()
{
for (int i = 0 ;i < rows;i ++ )
delete[] pMatrix[i];
delete[] pMatrix;
}

// 賦值函數
Matrix& Matrix::operator=(const Matrix& M)
{
if(this != &M)
{
for (int ii = 0 ;ii < rows;ii++ )
if(pMatrix[ii])
delete[] pMatrix[ii];
if(pMatrix)
delete[] pMatrix;
rows = M.rows;
columns = M.columns;
//分配存儲空間
pMatrix = new int* [rows];
for (int k = 0 ; k < rows; k++ )
pMatrix[k] = new int[columns];

for ( int i = 0 ; i < rows; i ++ )
for ( int j = 0 ; j < columns; j ++ )
pMatrix[i][j] = M.pMatrix[i][j];
}
return *this;
}
void Matrix::SetValue()
{
int i,j,value;
for ( i = 0 ; i < rows; i ++ )
{
for ( j = 0 ; j < columns; j ++ )
{
cout << " 第 " << i << " 行 " ;
cout << " 第 " << j << " 列: " ;
cin >> value;
cout << endl;
pMatrix[i][j] = value;
}
}
}
// 拷貝構造函數
Matrix::Matrix(const Matrix& M)
{
rows = M.rows;
columns = M.columns;
//分配存儲空間
pMatrix = new int* [rows];
for (int k = 0 ; k < rows; k++ )
pMatrix[k] = new int[columns];

for ( int i = 0 ; i < rows; i ++ )
for ( int j = 0 ; j < columns; j ++ )
pMatrix[i][j] = M.pMatrix[i][j];
}

Matrix operator*(const Matrix& a,const Matrix& b)
{
if (a.columns == b.rows)
{
Matrix c(a.rows,b.columns);
for ( int i = 0 ;i < a.rows;i ++ )
{
for ( int j = 0 ;j < b.columns;j ++ )
{
for ( int columnIndex= 0 ;columnIndex < a.columns;columnIndex++ )
c.pMatrix[i][j] += a.pMatrix[i][columnIndex] * b.pMatrix[columnIndex][j];
}
}
return c;
}
else
return Matrix();
}

ostream& operator<<(ostream& os,const Matrix& M)
{
for (int i = 0;i < M.rows;i++ )
{
for (int j = 0;j < M.columns;j++ )
os << M.pMatrix[i][j] << " ";
os << endl;
}
return (os << endl);
}


// 主函數
void main()
{
Matrix Ma(3,2),Mb(2,2);
Ma.SetValue();
Mb.SetValue();
cout << Ma << endl;
cout << Mb << endl;

Matrix Mc = Ma * Mb;//拷貝構造函數
cout << Mc << endl;
Mc = Mb; //=運算符,即賦值函數
cout << Mb << endl;
}   回復  更多評論
  
# re: [求助] 關于拷貝構造函數,對象傳遞!!
2006-04-12 20:53 | roa420
還是有錯,編譯出現7個錯誤!
ostream& operator<<(ostream& os,const Matrix& M) 中沒有權限訪問類中私有的rows和columns 這兩個成員。
  回復  更多評論
  
# re: [求助] 關于拷貝構造函數,對象傳遞!!
2006-04-12 21:49 | 華劍緣
不是呀,我這里編譯,運行都沒出錯呀  回復  更多評論
  
# re: [求助] 關于拷貝構造函數,對象傳遞!!
2006-04-13 12:48 | 史傳紅
@roa420
我在Visual C++ 6.0中編譯的時候也出現過問題,我懷疑它對友元支持的不好。
建議你換一個編譯器試試看。  回復  更多評論
  
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            亚洲一区制服诱惑| 久久国产精品黑丝| 国产精品日韩专区| 欧美日韩一区二区三区四区在线观看 | 亚洲欧美激情视频| 小处雏高清一区二区三区| 亚洲欧美在线视频观看| 欧美一区二区在线观看| 久久激情五月婷婷| 免费h精品视频在线播放| 亚洲国产成人精品久久久国产成人一区 | 久热综合在线亚洲精品| 欧美激情第五页| 国产精品国产福利国产秒拍| 国产日韩精品一区| 亚洲经典三级| 午夜精品亚洲| 欧美成人一品| 宅男精品视频| 久久久成人精品| 欧美精品一区二区精品网| 国产精品户外野外| 亚洲第一在线| 欧美亚洲三区| 亚洲精品偷拍| 新片速递亚洲合集欧美合集| 欧美成va人片在线观看| 国产伦一区二区三区色一情| 亚洲国产精品一区二区久| 香蕉av福利精品导航| 亚洲大胆人体视频| 亚洲综合电影| 欧美国产91| 加勒比av一区二区| 亚洲中字黄色| 亚洲国产精品久久久久婷婷老年| 亚洲在线日韩| 欧美日韩影院| 亚洲国产一区二区三区在线播| 亚洲天堂激情| 亚洲福利视频一区二区| 欧美在线观看视频一区二区三区 | 久久综合五月| 国产欧美日韩亚洲| 亚洲一区二区三区四区在线观看 | 亚洲欧美日韩综合aⅴ视频| 免费一区二区三区| 亚洲欧美另类综合偷拍| 国产精品大片| 一区二区日韩免费看| 欧美大片免费观看| 久久深夜福利免费观看| 欧美一区二区三区久久精品| 六月婷婷久久| 精品96久久久久久中文字幕无| 亚洲欧美在线观看| 一本色道久久综合亚洲精品婷婷 | 欧美一区二区精品在线| 日韩一二在线观看| 欧美激情一区在线| 亚洲高清自拍| 欧美成人国产一区二区| 香蕉尹人综合在线观看| 国产精品美女黄网| 亚洲一区中文字幕在线观看| 日韩视频永久免费| 欧美性淫爽ww久久久久无| 国产精品国产三级国产aⅴ入口| 亚洲美女视频网| 亚洲精品视频在线观看免费| 欧美日韩国产综合久久| 一区二区免费在线视频| 一本色道久久综合狠狠躁篇的优点 | 亚洲欧美日韩国产一区| 一本色道久久88精品综合| 欧美日韩中文| 亚洲欧美三级在线| 午夜在线一区二区| 黄色成人在线网站| 亚洲国产成人精品女人久久久| 欧美电影资源| 亚洲一级高清| 亚洲免费一在线| 国内成人精品2018免费看| 久久综合久色欧美综合狠狠| 老色批av在线精品| 日韩一区二区高清| 亚洲一区二区三区在线| 在线成人免费视频| 亚洲日本在线观看| 国产日韩精品综合网站| 蜜臀av一级做a爰片久久| 久久免费午夜影院| 一本色道久久综合狠狠躁的推荐| 亚洲欧美日韩在线| 亚洲国产另类久久精品| 亚洲美女黄色片| 国产精品日韩在线观看| 欧美96在线丨欧| 欧美日韩调教| 久久色中文字幕| 欧美激情一区二区三区蜜桃视频| 亚洲欧美日韩一区二区三区在线观看| 久久福利资源站| 久久中文精品| 国产精品久久久久久久app| 久久久久久尹人网香蕉| 亚洲激情一区| 国产精品一区二区三区久久久| 日韩一区二区精品| 亚洲欧美中文日韩v在线观看| 欧美精品一区二区三区蜜桃| 欧美成人亚洲成人日韩成人| 午夜天堂精品久久久久| 久久精品在这里| 亚洲精品中文在线| 在线亚洲国产精品网站| 亚洲第一天堂av| 欧美一区二区三区喷汁尤物| 亚洲视频在线播放| 免费一级欧美片在线观看| 欧美在线视频免费| 欧美日韩视频一区二区| 亚洲国产高清aⅴ视频| 在线国产欧美| 久久爱另类一区二区小说| 香蕉久久精品日日躁夜夜躁| 欧美精品一区二区三区很污很色的 | 91久久国产综合久久| 国内精品免费午夜毛片| 亚洲一区二区三区成人在线视频精品| 亚洲高清视频中文字幕| 狂野欧美性猛交xxxx巴西| 久久久亚洲影院你懂的| 国产日韩在线一区| 午夜精品短视频| 久久激五月天综合精品| 国产精品揄拍500视频| 夜夜嗨av一区二区三区中文字幕 | 欧美成人精品一区二区| 欧美国产亚洲精品久久久8v| 在线播放视频一区| 乱码第一页成人| 欧美成人xxx| 亚洲精品系列| 欧美精品九九99久久| 亚洲精品免费在线播放| 日韩亚洲精品电影| 欧美日韩午夜激情| 亚洲一区高清| 久久婷婷久久| 亚洲国产精品欧美一二99| 欧美精品乱码久久久久久按摩| 亚洲国产一区在线| 亚洲亚洲精品三区日韩精品在线视频| 欧美精品久久一区| 亚洲性图久久| 亚洲午夜免费福利视频| 欧美日韩国产在线观看| 亚洲人体大胆视频| 亚洲人成亚洲人成在线观看图片| 先锋影音国产一区| 久热国产精品| 一本色道久久加勒比88综合| 欧美视频日韩视频| 久久综合婷婷| 亚洲国内精品在线| 国产精品video| 亚洲欧美自拍偷拍| 欧美福利电影网| 亚洲欧洲一区二区三区| 欧美片在线观看| 亚洲一区二区视频在线观看| 久久成人羞羞网站| 亚洲欧洲在线一区| 欧美日韩一区二区三区| 久久精品在线免费观看| 亚洲狼人综合| 久久综合电影| 亚洲手机成人高清视频| 海角社区69精品视频| 欧美巨乳在线观看| 久久精品在线观看| 一区二区三区欧美视频| 欧美成人一区在线| 午夜欧美大尺度福利影院在线看| 精品av久久707| 欧美色精品在线视频| 美女视频黄 久久| 亚洲在线观看免费视频| 亚洲精品在线免费| 麻豆精品精品国产自在97香蕉| 日韩亚洲视频在线| 国产一区二区高清不卡| 欧美日韩国产综合久久| 久热精品视频在线观看| 久久精品人人做人人综合| 亚洲精品免费一区二区三区| 欧美激情无毛| 久久午夜精品|