PanduanBs

Perhitungan Matriks Menggunakan CPP / C++

Perhitungan Matriks Menggunakan CPP / C++

Halo sobat PANDUANBS. Bagaimana kabarnya? sebelumnya saya ucapkan selamat menunaikan ibadah puasa di bulan ramadhan 1440 h. Semoga bagi kalian yang menjalankannya di perlancar ibadah puasanya. Sudah tidak terasa 28 hari lagi idul fitri telah datang. Saya mewakili sebagai admin PANDUANBS mengucapkan mohon maaf lahir batin πŸ™‚

Oke langsung saja saya akan membagikan project lama ketika kuliah pada matkul Algoritma Pemograman (Alpro) semester 1 di Universitas Negeri Semarang (Unnes). Jadi ceritanya diberi tugas oleh dosen suruh membuat pemograman untuk menghitung atau mengopreasikan 2 matriks atau lebih menggunakan cpp.

Fitur Perhitungan Matriks dengan CPP

Beberapa fitur yang harus ada diantaranya adalah:

  1. Penjumlahan (banyak) Matriks
  2. Pengurangan (banyak) Matriks
  3. Perkalian (banyak) Matriks
  4. Determinan (banyak) Matriks
  5. Invers Matriks 2×2

Preview Perhitungan Matriks

Berikut kurang lebih yang akan dihasilkan dari program perhitungan matriks menggunakan CPP / C++

chrome J6b4MXAmRq
screenshot perhitungan matriks

Source Code Perhitungan Matriks CPP

Ini sudah saya siapkan souce code cpp untuk perhitungan lengkap matriks. Saya harap sobat tidak hanya copy dan paste saja, silahkan dicermati ini dari codenya. karena saya tidak akan menjelaskan secara detail. jika ada pertanyaan atau kurang paham silahkan tuliskan saja di kolom komentar.

#include <iostream>
#include <stdlib.h>
using namespace std;

void penjumlahan()
{	 				
			int m,n;
			cout<< "Jumlah matriks : ";
			cin >> m;
			cout<< "Ordo (kolom & baris) Matriks : ";
			cin >> n;
			int a[n][n], b[n][n], c[n][n];
			
			
			cout<< endl << "MATRIKS ke-1" << endl;
			for (int i=0; i<n; ++i){
				for (int j=0; j<n; ++j){
					cout<< "Matriks" << i+1 << j+1 << " : ";
					cin >> a[i][j];
				}
			}
			
			for (int i=0; i<n; ++i){
				for (int j=0; j<n; ++j){
					cout<<a[j][j] << " ";
				}
				cout<<endl;
			}
			
			cout<< endl;
			
			for (int k=1; k<m; ++k){
				cout<< "MATRIKS ke-" << k+1 << endl;
				for (int i=0; i<n; ++i){
					for (int j=0; j<n; ++j){
						cout<< "Matriks" << i+1 << j+1 << " : ";
						cin >> b[i][j];
						a[i][j]=a[i][j]+b[i][j];
					}
				}
			for (int i=0; i<n; ++i){
				for (int j=0; j<n; ++j){
					cout<<b[i][j] << " ";
				}
				cout<<endl;
			}
				cout<< endl;
			}
			
			cout<< "Hasil penjumlahan dari "<<m<<" matriks berordo "<<n<<"x"<<n<<" adalah: " << endl;
			for (int i=0; i<n; ++i){
				for (int j=0; j<n; ++j){
					cout<<a[i][j] << " ";
				}
			cout<<endl;
			}
		cout<<endl;
}

void pengurangan()
{	 				
 			int m, n;
			cout<< "Jumlah matriks : ";
			cin >> m;
			cout<< "Ordo (kolom & baris) Matriks : ";
			cin >> n;
			int a[n][n], b[n][n], c[n][n];
			
			cout<< endl << "MATRIKS ke-1" << endl;
			for (int i=0; i<n; ++i){
				for (int j=0; j<n; ++j){
					cout<< "Matriks" << i+1 << j+1 << " : ";
					cin >> a[i][j];
				}
			}
			
			for (int i=0; i<n; ++i){
				for (int j=0; j<n; ++j){
					cout<<a[j][j] << " ";
				}
				cout<<endl;
			}
			
			cout<< endl;
			
			for (int k=1; k<m; ++k){
				cout<< "MATRIKS ke-" << k+1 << endl;
				for (int i=0; i<n; ++i){
					for (int j=0; j<n; ++j){
						cout<< "Matriks" << i+1 << j+1 << " : ";
						cin >> b[i][j];
						a[i][j]=a[i][j]-b[i][j];
					}
				}
			for (int i=0; i<n; ++i){
				for (int j=0; j<n; ++j){
					cout<<b[i][j] << " ";
				}
				cout<<endl;
			}
				cout<< endl;
			}
			
			cout<< "Hasil pengurangan dari "<<m<<" matriks berordo "<<n<<"x"<<n<<" adalah: " << endl;
			for (int i=0; i<n; ++i){
				for (int j=0; j<n; ++j){
					cout<<a[i][j] << " ";
				}
			cout<<endl;
			}
		cout<<endl;		
}

void perkalian()
{
 			int m, n, a[n][n], b[n][n], c[n][n];
			cout<< "Jumlah matriks : ";
			cin >> m;
			cout<< "Ordo (kolom & baris) Matriks : ";
			cin >> n;
			
			cout<< endl << "MATRIKS ke-1" << endl;
			for (int i=0; i<n; ++i){
				for (int j=0; j<n; ++j){
					cout<< "Matriks" << i+1 << j+1 << " : ";
					cin >> a[i][j];
				}
			}
			
			for (int i=0; i<n; ++i){
				for (int j=0; j<n; ++j){
					cout<<a[j][j] << " ";
				}
				cout<<endl;
			}
			
			cout<< endl;
			
			for (int k=1; k<m; ++k){
				cout<< "MATRIKS ke-" << k+1 << endl;
				for (int i=0; i<n; ++i){
					for (int j=0; j<n; ++j){
						cout<< "Matriks" << i+1 << j+1 << " : ";
						cin >> b[i][j];
					}
				}
				
				for (int i=0; i<n; ++i){
					for (int j=0; j<n; ++j){
						c[i][j]=0;
						for (int k=0; k<n; ++k){
							c[i][j]=c[i][j]+(a[i][k]*b[k][j]);
						}
					}
				}				
				
			for (int i=0; i<n; ++i){
				for (int j=0; j<n; ++j){
					cout<<b[i][j] << " ";
					a[i][j]=c[i][j];
				}
				cout<<endl;
			}
				cout<< endl;
			}
			
			cout<< "Hasil perkalian dari "<<m<<" matriks berordo "<<n<<"x"<<n<<" adalah: " << endl;
			for (int i=0; i<n; ++i){
				for (int j=0; j<n; ++j){
					cout<<c[i][j] << " ";
				}
			cout<<endl;
			}
		cout<<endl;
}

void determinan()
{
	int i, j, k, n, hasil;
		  menu2:
		  system("CLS");
		  cout<<"------------------------------------------------"<<endl;
		  cout<<"    >>  Anda memilih Determinan Matriks  <<"     <<endl;
		  cout<<"------------------------------------------------"<<endl;
		  cout<<"=========PILIHAN========="<<endl;		  
		  cout<<"|    1. Matriks 2x2	|"<<endl;
		  cout<<"|    2. Matriks 3x3	|"<<endl;
		  cout<<"|    0. Kembali		|"<<endl;
		  cout<<"========================="<<endl;
		  cout<<"Masukkan pilihan (0/1/2): ";
		  cin>>k;
	int a[k+1][k+1];
	n=k+1;		  
	
	    // Memasukkan Nilai Matriks.
	    if(k<3){
			if(k==0){
		  system("CLS");
		  cout<<"------------------------------------------------"<<endl;
          cout<<"    >>  Klik untuk melanjutkan ke Menu  <<  "<<endl;
		  cout<<"------------------------------------------------"<<endl;
		  	}
			else if (k==1 || k==2)
				{
    			cout << endl << "MATRIKS:" << endl; 
    			for(i = 0; i <n ; i++)
        			for(j = 0; j <n ; j++)
        			{
            			cout << "Matriks" << i + 1 << j + 1 << " : ";
            			cin >> a[i][j];
        			}
    			}
    		}
	   		else{
		  system("CLS");
		  cout<<"------------------------------------------------"<<endl;
          cout<<"        >> Tidak ada dalam pilihan  <<  "<<endl;
		  cout<<"------------------------------------------------"<<endl;
 system ("PAUSE");		  
		  goto menu2;
			}
			 

	if (k<3){ //Proses
		if (k==1){
		hasil=(a[0][0]*a[1][1])-(a[0][1]*a[1][0]);
		    // Menampilkan Hasil Determinan.
   		cout<<endl<< "Hasil Determinan : "<<hasil<< endl;
		}
		else if (k==2){
		hasil=a[0][0]*a[1][1]*a[2][2]+a[0][1]*a[1][2]*a[2][0]+a[0][2]*a[1][0]*a[2][1]-a[2][0]*a[1][1]*a[0][2]-a[2][1]*a[1][2]*a[0][0]-a[2][2]*a[1][0]*a[0][1];	
		    // Menampilkan Hasil Determinan.
   		cout<<endl<< "Hasil Determinan : "<<hasil<< endl;
		}
		else{
		cout<<endl;
		}
	}
	cout<<endl;
	
}

void invers()
{
	int a[10][10], b[10][10], bar1, kol1, i, j, k;
	float det,inv[10][10];

	bar1=2;
	kol1=2;
	
	    // Memasukkan Nilai Matriks.
    cout << endl << "MATRIKS:" << endl;
    for(i = 0; i < bar1; ++i)
        for(j = 0; j < kol1; ++j)
        {
            cout << "Matriks" << i + 1 << j + 1 << " : ";
            cin >> a[i][j];
        }

	//Proses
	det=(a[0][0]*a[1][1])-(a[0][1]*a[1][0]);
	
	//Pembalikan
	b[i][j];
	b[0][0]=a[1][1];
	b[1][1]=a[0][0];
	b[0][1]=-1*a[0][1];
	b[1][0]=-1*a[1][0];
	
	//invers
    for(i = 0; i < bar1; ++i)
    for(j = 0; j < kol1; ++j)
    {
    	inv[i][j]=1/det*b[i][j];
    }	
	
	//Menampilkan
	cout << endl << "Hasil Invers: " << endl;
    for(i = 0; i < bar1; ++i)
    for(j = 0; j < kol1; ++j)
    {
    	cout << " " << inv[i][j];
    	if(j == kol1-1)
        cout << endl;
    }
	cout<<endl;	
}

int main()//Program Utama
{
menu:
system("CLS");
int pil;
cout<<"********  program by: Ahmad Fauza Aulia  ********"<<endl;
cout<<"-----------------  4611417038  ------------------"<<endl;
cout<<endl;
cout<<"-------------------------------------------------"<<endl;
cout<<"     >>  PROGRAM PERHITUNGAN MATRIKS  <<"<<endl;
cout<<"-------------------------------------------------"<<endl;
cout<<"====================PILIHAN======================"<<endl;
cout<<"|    1. Penjumlahan Matriks 			|"<<endl;
cout<<"|    2. Pengurangan Matriks 			|"<<endl;
cout<<"|    3. Perkalian matriks   			|"<<endl;
cout<<"|    4. Determinan matriks			|"<<endl;
cout<<"|    5. Invers matriks 2x2			|"<<endl;
cout<<"|    6. Keluar Program				|"<<endl;
cout<<"================================================="<<endl;
cout<<"Masukkan pilihan (1/2/3/4/5/6): ";
cin>>pil;

switch(pil)
{
case 1:
//perintah pilihan 1
				system("CLS");
				cout<<"------------------------------------------------"<<endl;
				cout<<"   >>  Anda memilih Penjumlahan Matriks  <<"<<endl;
				cout<<"------------------------------------------------"<<endl;
			    penjumlahan();
			    system ("PAUSE");
			    goto menu;
          break;

case 2:
//Perintah pilihan 2
				system("CLS");
				cout<<"------------------------------------------------"<<endl;
				cout<<"   >>  Anda memilih Pengurangan Matriks  <<"<<endl;
				cout<<"------------------------------------------------"<<endl;
				pengurangan();
				system ("PAUSE");
				goto menu;
          break;

case 3:
//Perintah pilihan 3
				system("CLS");
				cout<<"------------------------------------------------"<<endl;
				cout<<"    >>  Anda memilih Perkalian Matriks  <<"<<endl;
				cout<<"------------------------------------------------"<<endl;
				perkalian();
				system ("PAUSE");
				goto menu;
          break;

case 4:
//Perintah pilihan 4
		  		determinan();
			    system ("PAUSE");
			    goto menu;
          break;

case 5:
//Perintah pilihan 5
				system("CLS");
				cout<<"------------------------------------------------"<<endl;
		  		cout<<"    >>  Anda memilih Invers Matriks 2x2  <<"     <<endl;
				cout<<"------------------------------------------------"<<endl;
				invers();
				system ("PAUSE");
				goto menu;
          break;
          
case 6:
//Perintah pilihan 6
		  system("CLS");
		  cout<<"------------------------------------------------"<<endl;
		  cout<<"    >>  Anda telah keluar dari program  <<  "<<endl;
		  cout<<"------------------------------------------------"<<endl;
          break;
default:
		  system("CLS");
		  cout<<"------------------------------------------------"<<endl;
          cout<<"        >> Tidak ada dalam pilihan  <<  "<<endl;
		  cout<<"------------------------------------------------"<<endl;
          system ("PAUSE");
		  goto menu;
          break;
}
}

Live Preview

Diawah ini, juga telah saya berikan live preview kepada sobat supaya dapat secara langsung melihat hasil dari program perhitngan matriks menggunakan bahasa pemograman cpp/c++. Dengan live preview dibawah ini sobat juga bisa dengan mudah mensimulasikannya atau ingin improv sendiri. Silahkan klik tombol ‘run‘ dibawah ini.

Terima kasih sudah berkunjung dan membca artikel dari PANDUANBS. Semoga dapat bermanfaat bagi kita semua. Jika ingin mendapatkan informasi terbaru dari PANDUANBS. silahkan ketik email sobat dan subscribe. πŸ™‚

Baca artikel terbaru kami

Add comment

Follow Me

Follow Saya supaya kamu tidak kentinggalan informasi menarik dari Panduanbs.

AdBlocker Message

Our website is made possible by displaying online advertisements to our visitors. Please consider supporting us by disabling your ad blocker.