c++實現矩陣乘法

来源:http://www.cnblogs.com/shuiming/archive/2016/04/02/5348644.html
-Advertisement-
Play Games

重載*運算符為友元函數。 ...


重載*運算符為友元函數。

  1 #include <iostream>
  2 #include <cmath> 
  3 using namespace std;
  4 
  5 class Matrix{
  6     public:
  7         Matrix(){}
  8         Matrix(int,int);
  9         void setMatrix();
 10         void showMatrix();
 11         void showTransposedMatrix();
 12         friend Matrix operator *(Matrix m1,Matrix m2);
 13     protected:
 14         int m;
 15         int n;
 16         int mn;
 17         double* matrixPtr;
 18         double* transposedMPtr;
 19         void transpose();
 20 };
 21 
 22 class SquareMatrix:public Matrix{
 23     public:
 24         SquareMatrix(){}
 25         SquareMatrix(int);
 26         void setSquareMatrix();
 27         void setDet();
 28         void getDet();
 29     private:
 30         double det;
 31 };
 32 
 33 Matrix::Matrix(int mt,int nt){
 34     m=mt;
 35     n=nt;
 36     mn=m*n;
 37     matrixPtr=new double[mn];
 38 }
 39 
 40 void Matrix::setMatrix(){
 41     cout<<"輸入矩陣的行數和列數:"<<endl;
 42     cin>>m>>n;
 43     mn=m*n;
 44     matrixPtr=new double[mn];
 45     for(int i=0;i<mn;i++)
 46         cin>>matrixPtr[i];
 47 }
 48 
 49 void Matrix::transpose(){
 50     transposedMPtr=new double[mn];
 51     for(int i=0;i<n;i++)
 52         for(int j=0;j<m;j++)
 53             transposedMPtr[m*i+j]=matrixPtr[n*j+i];
 54 }
 55 
 56 void Matrix::showMatrix(){
 57     for(int i=0;i<m;i++){
 58         for(int j=0;j<n;j++)
 59             cout<<matrixPtr[n*i+j]<<' ';
 60         cout<<endl;
 61     }
 62 }
 63 
 64 void Matrix::showTransposedMatrix(){
 65     for(int i=0;i<n;i++){
 66         for(int j=0;j<m;j++)
 67             cout<<transposedMPtr[m*i+j]<<' ';
 68         cout<<endl;
 69     }
 70 }
 71 
 72 Matrix operator *(Matrix m1,Matrix m2){
 73     Matrix m3(m1.m,m2.n);
 74     for(int i=0;i<m3.m;i++)
 75         for(int j=0;j<m3.n;j++){
 76             double val=0;
 77             for(int k=0;k<m2.m;k++)
 78                 val+=m1.matrixPtr[m1.n*i+k]*m2.matrixPtr[m2.n*k+j];
 79             m3.matrixPtr[m3.n*i+j]=val;
 80         }
 81     return m3;
 82 }
 83 
 84 SquareMatrix::SquareMatrix(int m){
 85     Matrix(m,m);                      //right?
 86 }
 87 
 88 void SquareMatrix::setSquareMatrix(){
 89     cout<<"輸入方陣的階數:"<<endl;
 90     cin>>m;
 91     n=m; 
 92     mn=m*n;
 93     matrixPtr=new double[mn];
 94     for(int i=0;i<mn;i++)
 95         cin>>matrixPtr[i];
 96 }
 97 
 98 void SquareMatrix::setDet(){
 99     double valDet(double*,int);
100     det=valDet(matrixPtr,m);
101 }
102 
103 void SquareMatrix::getDet(){
104     cout<<det<<endl;
105 }
106 double valDet( double *detPtr, int rank)
107 {
108     double val=0;
109     if(rank==1) return detPtr[0];
110     for(int i=0;i<rank;i++)                   //計算餘子式保存在nextDetPtr[]中 
111     {
112         double *nextDetPtr=new double[(rank-1)*(rank-1)];
113         for(int j=0;j<rank-1;j++)
114             for(int k=0;k<i;k++)
115                 nextDetPtr[j*(rank-1)+k]=detPtr[(j+1)*rank+k];
116         for(int j=0;j<rank-1;j++)
117             for(int k=i;k<rank-1;k++)
118                 nextDetPtr[j*(rank-1)+k]=detPtr[(j+1)*rank+k+1];
119         val+=detPtr[i]*valDet(nextDetPtr,rank-1)*pow(-1.0,i);
120     }
121     return val;
122 }
123 
124 int main(){
125     Matrix m1,m2,m3;
126     m1.setMatrix();
127     m2.setMatrix();
128     m3=m1*m2;
129     m3.showMatrix();
130     return 0;
131 }

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 引言 這是關於C中如何使用異常機制的討論.順帶講一講C中魔法函數的setjmp內部機制.通過它實現高級的異常try...catch. 允許我先扯一段面試題. 對於電腦面試題. 演算法題等.覺得還是有意義的. 在你封裝基礎庫的時候會簡單用的.因為大家都會得你也會那是及格.如果你想及格+1的話... 開 ...
  • (初學者都會問一個問題,就是Eclipse好用還是Myeclipse好用。好吧,這個問題我昨晚才剛剛問完,哈哈,因為我一開始學Java都是直接下了一個MyeClipse來用的,沒想過太多。其實也是,兩者其實都只是一個開發工具,沒必要糾結太多,不過事實上Myeclipse給我感覺是一個集成環境比較好的 ...
  • 1 #include <stdio.h> 2 #include <string.h> //字元串處理庫 3 4 char tracks[][80]={ 5 "I left my heart in Harvard Med School", 6 "Newwark,Newwark - a wonderfu ...
  • 沒有很多東西,就是為了自己方便,編寫啦一段代碼,用來一鍵開啟博客園主頁。 恢復內容結束 ...
  • ...
  • 作為一個菜鳥,剛開始用java連接sqlserver的時候,用的時間不短, 可以說解決了一個又出現一個,所以我覺得有必要把我的經驗分享給大家。 (因為我踩了大部分的坑) 第一個坑:載入驅動。java要連接資料庫就需要驅動,我們去網上下載一個 sqljdbc.jar就行了。下載後該怎麼做呢。 這個時候 ...
  • 這篇文章有點深度,可能需要一些Lucene或者全文檢索的背景。由於我也很久沒有看過Lucene了,有些地方理解的不對還請多多指正。 更多內容 "還請參考整理的ELK教程" 關於Term Vectors 額,對於這個專業辭彙,暫且就叫做詞條向量吧,因為實在想不出什麼標準的翻譯。說的土一點,也可以理解為 ...
  • 原創,未經允許,禁止轉載!!! 分析依據:先載入的不能直接調用後載入的,因為後載入的並不存在無法被使用 後載入的能直接使用先載入的,因為先載入的已存在可以被使用比如:靜態方法先於實例變數,所以靜態方法直接調用實例變數就不行,因為實例變數還不在記憶體中,如下列代碼: 以此為依據使用debug得到分析結論 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...