欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

C++實(shí)現(xiàn)對(duì)象化的矩陣相乘小程序

 更新時(shí)間:2021年09月16日 16:09:30   作者:超自然祈禱  
這篇文章主要為大家詳細(xì)介紹了C++實(shí)現(xiàn)對(duì)象化的矩陣相乘小程序,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下

復(fù)習(xí)數(shù)學(xué)1的線性代數(shù),矩陣相乘這塊有點(diǎn)暈,想編個(gè)C++對(duì)象化的矩陣相乘小程序。

相乘部分

void sum(juzhen a, juzhen b, juzhen &c)
{
 int s=0;
 for (int i = 1; i <= a.m1(); i++)//A矩陣的M
  for (int j = 1; j <= b.n1(); j++)//B矩陣的S
  {
   for (k0 = 1; k0 <= a.n1(); k0++)//a.n1也就是b.m1(a的n,b的n)【行向量*列向量】
   {
    s += a.read(i,k0)*b.read(k0,j);
   }
    c.write(i, j, s);
    s = 0;
  }
}

公式:

代碼中的頭兩個(gè)for循環(huán)就是i,j的。公式中的k從1到p求和就是里面的k0的for循環(huán)。

容易出現(xiàn)誤解的就是公式中只是表示第“[i][j]”元素,而不是整個(gè)矩陣,整個(gè)矩陣的結(jié)果需要外面的兩個(gè)for循環(huán)。

本質(zhì):這就是個(gè)p維向量(高中就記2維)的兩向量相乘公式而已【結(jié)果為數(shù),是新矩陣的一個(gè)元素】

可運(yùn)行代碼:

#include<iostream>
#include <string>
using namespace std;
 
class juzhen
{
private:
 int m,n;//長(zhǎng)寬
 int num[10][10] = {0};
 string name;
 
public:
  void size(int a,int b)
  { m = a;
  n = b; }
  void set()
  {
   cout << "此矩陣規(guī)模:" << this->m <<","<< this->n << endl;//=====?
   for (int i = 1; i <= this->m; i++)
    for (int j = 1; j <= this->n; j++)
    {
     cin >> this->num[i][j];
    }
   cout << "輸入完成"<< endl;
  }
  void display()
  {
   for (int i = 1; i <= this->m; i++)//===i為行號(hào)(第幾行),j為列號(hào)
    for (int j = 1; j <= this->n; j++)
    {
     cout << this->num[i][j] << " ";
    if (j == this->n) cout << endl;//先輸出再換行
    }
  }
  int read(int a, int b) { return num[a][b]; }//調(diào)用此函數(shù),得[m][n]元素的值
  void write(int a, int b,int count) {  num[a][b]=count; }//第三個(gè)參數(shù)的值,傳遞給[a][b]元素
  int m1() { return m; }//調(diào)用得到矩陣的m
  int n1() { return n; }//調(diào)用得到矩陣的n
};
 
int m0, n0, s0, k0;//矩陣規(guī)模(容易搞混的東西)
 
void sum(juzhen a, juzhen b, juzhen &c)//矩陣相乘公式所在。。?!疽膶?shí)參值的要用&引用】
{
 for (int i = 1; i <= a.m1(); i++)//A矩陣的M
  for (int j = 1; j <= b.n1(); j++)//B矩陣的S
  {
 
   int s = 0;
   for (k0 = 1; k0 <= a.n1(); k0++)//a.n1也就是b.m1(a的n,b的n)【行向量*列向量】
   {
    s += a.read(i,k0)*b.read(k0,j);//因?yàn)橛昧薈++,所以沒(méi)那么直觀,就是a[i][k]*b[k][j],套個(gè)for循環(huán)求累加和(就是高中時(shí)向量的點(diǎn)乘)
   }
    c.write(i, j, s);
  }
}
int main()
{
 juzhen A,B,C;
 cout << "設(shè)定m,s,n。A的m*s,B的s*n(橫條數(shù)*縱條數(shù))"<<endl;
 cin >> m0>> s0>> n0;
 A.size(m0, s0);
 B.size(s0, n0);
 
 C.size(m0, n0);
 
 A.set();
 B.set();
 
 sum(A, B, C);//C=A*B
 cout << "結(jié)果C的m*n:" << endl;
 C.display();
 
 return 0;
}

樣例輸入及輸出:

1 0          1 0           1 0
0 1      *   0 1      =   0 1

如圖所示兩個(gè)矩陣

懶得打了……就如圖所示兩個(gè)矩陣

PS:函數(shù)中形參引用真好用,過(guò)去一直不知道,省得用指針了。(不然改不了C矩陣的實(shí)際元素值)

void sum(juzhen a, juzhen b, juzhen &c) 
//矩陣相乘公式所在。。?!疽膶?shí)參值的要用&引用】

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • C++?Qt實(shí)現(xiàn)動(dòng)態(tài)增加垂直滾動(dòng)條

    C++?Qt實(shí)現(xiàn)動(dòng)態(tài)增加垂直滾動(dòng)條

    本博文源于筆者正在工作的一個(gè)小內(nèi)容,內(nèi)容涉及到為qt動(dòng)態(tài)增加垂直滾動(dòng)條,文章分為三個(gè)部分,問(wèn)題起源,問(wèn)題解決方案,問(wèn)題解決成功效果,思路清晰,文章干貨滿滿,復(fù)制源碼即可使用,需要的朋友可以參考下
    2023-08-08
  • C++帶頭雙向循環(huán)鏈表超詳細(xì)解析

    C++帶頭雙向循環(huán)鏈表超詳細(xì)解析

    帶頭雙向循環(huán)鏈表:結(jié)構(gòu)最復(fù)雜,一般用在單獨(dú)存儲(chǔ)數(shù)據(jù)。實(shí)際中使用的鏈表數(shù)據(jù)結(jié)構(gòu),都是帶頭雙向循環(huán)鏈表。另外這個(gè)結(jié)構(gòu)雖然結(jié)構(gòu)復(fù)雜,但是使用代碼實(shí)現(xiàn)以后會(huì)發(fā)現(xiàn)結(jié)構(gòu)會(huì)帶來(lái)很多優(yōu)勢(shì),實(shí)現(xiàn)反而簡(jiǎn)單
    2022-03-03
  • QT委托代理機(jī)制之Model?View?Delegate使用方法詳解

    QT委托代理機(jī)制之Model?View?Delegate使用方法詳解

    這篇文章主要介紹了QT委托代理機(jī)制之Model?View?Delegate的使用方法,對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2022-08-08
  • 利用C語(yǔ)言實(shí)現(xiàn)將格式化數(shù)據(jù)和字符串相互轉(zhuǎn)換

    利用C語(yǔ)言實(shí)現(xiàn)將格式化數(shù)據(jù)和字符串相互轉(zhuǎn)換

    這篇文章主要為大家詳細(xì)介紹了2個(gè)函數(shù),分別是sprintf和sscanf,可以用來(lái)實(shí)現(xiàn)將格式化數(shù)據(jù)和字符串相互轉(zhuǎn)換,感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下
    2023-03-03
  • 設(shè)計(jì)模式中的備忘錄模式解析及相關(guān)C++實(shí)例應(yīng)用

    設(shè)計(jì)模式中的備忘錄模式解析及相關(guān)C++實(shí)例應(yīng)用

    這篇文章主要介紹了設(shè)計(jì)模式中的備忘錄模式解析及相關(guān)C++實(shí)例應(yīng)用,備忘錄模式也經(jīng)常被用來(lái)在命令模式中維護(hù)可以撤銷(xiāo)(Undo)操作的狀態(tài),需要的朋友可以參考下
    2016-03-03
  • Qt+QWidget實(shí)現(xiàn)簡(jiǎn)約美觀的加載動(dòng)畫(huà)

    Qt+QWidget實(shí)現(xiàn)簡(jiǎn)約美觀的加載動(dòng)畫(huà)

    這篇文章主要為大家詳細(xì)介紹了Qt如何結(jié)合QWidget實(shí)現(xiàn)簡(jiǎn)約美觀的加載動(dòng)畫(huà),文中的示例代碼講解詳細(xì),感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下
    2024-02-02
  • c++和python實(shí)現(xiàn)順序查找實(shí)例

    c++和python實(shí)現(xiàn)順序查找實(shí)例

    這篇文章主要介紹了c++和python實(shí)現(xiàn)順序查找實(shí)例,流程即將目標(biāo)數(shù)值和數(shù)據(jù)庫(kù)中的每個(gè)數(shù)值進(jìn)行比較,如果相同則搜索完成,如果不同則繼續(xù)比較下一處,下面來(lái)看看具體的實(shí)例操作吧,需要的朋友可以參考一下
    2022-03-03
  • C++如何實(shí)現(xiàn)DNS域名解析

    C++如何實(shí)現(xiàn)DNS域名解析

    這片文章介紹了C++如何實(shí)現(xiàn)DNS域名解析,還有對(duì)相關(guān)技術(shù)的介紹,代碼很詳細(xì),需要的朋友可以參考下
    2015-07-07
  • C++下程序運(yùn)行時(shí)間的四種常用計(jì)時(shí)方法總結(jié)

    C++下程序運(yùn)行時(shí)間的四種常用計(jì)時(shí)方法總結(jié)

    這篇文章主要介紹了C++下程序運(yùn)行時(shí)間的四種常用計(jì)時(shí)方法,介紹了幾種常用的計(jì)時(shí)方法,包括低精度的clock()和GetTickCount(),以及高精度的gettimeofday()和QueryPerformanceCounter(),需要的朋友可以參考下
    2024-09-09
  • C++11/14 線程中使用Lambda函數(shù)的方法

    C++11/14 線程中使用Lambda函數(shù)的方法

    這篇文章主要介紹了C++11/14 線程中使用Lambda函數(shù)的方法,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2019-01-01

最新評(píng)論