C/C++如何實現(xiàn)兩矩陣相乘之模擬法
數(shù)學(xué)中兩矩陣怎么相乘?
矩陣相乘需要前面矩陣的列數(shù)與后面矩陣的行數(shù)相同方可相乘。
將前面矩陣的第i行各元素分別與后面矩陣的第j列相應(yīng)位置元素相乘相加作為結(jié)果矩陣的第i行第j列。
eg:
上圖前面矩陣的列數(shù)是3,后面矩陣的行數(shù)是3,所以他倆的某一行和某一列才能一一對應(yīng),進而才能進行矩陣相乘運算;
C/C++語言實現(xiàn)
假設(shè)和上圖一樣的矩陣a*矩陣b
在草稿紙上模擬矩陣相乘的過程中,我們會發(fā)現(xiàn),第一個矩陣a 分別用自己的第i行與 第二個矩陣b的第j列行進行了對應(yīng)的元素相乘相加的操作;
那么雙重for循環(huán)(一個i~rowa 再包含一個j~colb)肯定少不了;
再觀察發(fā)現(xiàn)每次雙方的i行j列對應(yīng)元素相乘相加的次數(shù),也就第一個矩陣a的列數(shù),同時也是第二個矩陣b的行數(shù)(相乘的條件cola==rowb嘛)
那么第三重循環(huán)再嵌套一個 k~cola 或者 k~rowb的循環(huán)即可,這個循環(huán)的變量k用于處理對應(yīng)元素相乘相加的過程中,當(dāng)前應(yīng)該是矩陣a的第i行第k個元素*矩陣b的低j列低k個元素了(a[i][k]*b[k][j])
注意:我當(dāng)時就是這個第三重循環(huán)死活想不出來,就套了上面?zhèn)z循環(huán)在那里i,j的痛苦折磨
所以一共三個循環(huán)就能搞定,矩陣相乘模擬的過程,模擬的過程得自己細(xì)心體會,相當(dāng)于照貓畫虎的意思;
C語言實現(xiàn)只需要把vector換成數(shù)組arr即可,這里用vector想練習(xí)一下包含二維數(shù)組的vector的語法;
#include <iostream> #include <vector> using namespace std; vector<vector<int>> a = { {1,2,4},{2,0,3}};//矩陣a: 1 2 4 // 2 0 3 vector<vector<int>> b = { {1,2},{3,2},{0,5} }; //矩陣b: 1 2 // 3 2 // 0 5 int main() { //一般的編程題會輸入n,m作為某個矩陣的行和列,需要進行錄入矩陣操作: //... int rowa = 2;//第一個矩陣的行數(shù) int colb = 2;//第二個矩陣的列數(shù) int cola = 3;//第一個矩陣的列數(shù) 等價 第二個矩陣的行數(shù) vector<vector<int>> ret(rowa,vector<int>(colb,0));//保存結(jié)果的矩陣 //模擬進行矩陣a*矩陣b的運算 for (int i = 0; i < rowa; i++) { for (int j = 0; j < colb; j++) { int sum = 0; //存儲a矩陣低i行和b矩陣第j列 第k輪 的相乘累加和 for (int k = 0; k < cola ; k++) { sum += a[i][k] * b[k][j]; } ret[i][j] = sum; } } //打印結(jié)果矩陣(模擬觀察到,結(jié)果矩陣的行數(shù)也就是a矩陣的行數(shù),結(jié)果矩陣的列數(shù)也就是b矩陣的列數(shù)) for (int i = 0; i < rowa; i++) { for (int j = 0; j < colb; j++) { cout << ret[i][j] <<" "; } cout << endl; } return 0; }
運行結(jié)果
總結(jié)
到此這篇關(guān)于C/C++如何實現(xiàn)兩矩陣相乘之模擬法的文章就介紹到這了,更多相關(guān)C/C++兩矩陣相乘內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
C++實現(xiàn)TCP客戶端及服務(wù)器Recv數(shù)據(jù)篩選處理詳解
這篇文章主要為大家介紹了C++實現(xiàn)TCP客戶端及服務(wù)器Recv數(shù)據(jù)篩選處理詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2022-10-10使用C# 判斷給定大數(shù)是否為質(zhì)數(shù)的詳解
本篇文章是對使用C#判斷給定大數(shù)是否為質(zhì)數(shù)的方法進行了詳細(xì)的分析介紹,需要的朋友參考下2013-05-05C#桌面應(yīng)用開發(fā)實現(xiàn)番茄定時器
本文主要介紹了C#桌面應(yīng)用開發(fā)實現(xiàn)番茄定時器,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2024-07-07C語言匯編分析傳遞結(jié)構(gòu)體指針比傳遞結(jié)構(gòu)體變量高效的深層原因
本文章使用的工具是vs2010,本篇文章主要講解結(jié)構(gòu)體指針作為參數(shù)傳遞與結(jié)構(gòu)體變量作為參數(shù)傳遞的對比,不談值傳遞與址傳遞的概念2022-10-10