Skip to main content

MATRIX MULTIPLICATION

/**
    Program Name: MATRIX MULTIPLICATION

    Description: This program finds Product of Two Matrices

    Author:  Tauqirul Haque
       
*/



#define ROW1 2    //Change the Dimension According to Your need
#define COL1 2
#define ROW2 2
#define COL2 2



void productMatrix(int matrix[][COL1], int matrixB[][COL2], int productMatrix[][COL2]);
void displayMatrix(int matrix[ROW1][COL2]); //this function displays the matrix

void main()
{
    int matrixA[ROW1][COL1] = { 1,1,1,1 };
    int matrixB[ROW2][COL2] = { 2,2,2,2 };
    int proMatrix[ROW1][COL2]={0};  //this will store the product of two matrices
   
    printf("\nThe Element of the First Matrix is...\n");   
    displayMatrix(matrixA);
   
    printf("\nThe Element of the Second Matrix is ... \n");
    displayMatrix(matrixB);
   
    productMatrix(matrixA,matrixB,proMatrix);
   
    printf("\nThe Product of Matrices are ... \n");
    displayMatrix(proMatrix);
   
}

void productMatrix(int matrixA[ROW1][COL1], int matrixB[ROW2][COL2],int productMatrix[ROW1][COL2])
{
    int i,j,k;
       
    for(i=0;i
    {
        for(j=0;j
        {
             productMatrix[i][j]=0;
           
            for(k=0;k
            {
                productMatrix[i][j] += matrixA[i][k] * matrixB[k][j];
            }
        }
    }
}

void displayMatrix(int matrix[ROW1][COL2])
{
    int i,j;
    printf("\n");
   
    for(int i=0;i
    {
        for(int j=0;j
        {
            printf("%4d",matrix[i][j]);
        }
        printf("\n");
    }
}



Comments

Popular posts from this blog

Singly Linked List

/**     Program Name: Singly Linked List     Description: This Program is for Implemeting Singly Linked List     Author:  Tauqirul Haque         */ struct Linklist {     int item;     struct Linklist *next; }; typedef struct Linklist node; void insertAtBeginning(node **); void createAppendNode(node **); void insertInMiddle(node **); void deleteNode(node **); void displayNode(node **); void countNode(node **);  void searchElement(node **); void reverse(node **); void main() {     node *head = NULL;     int choice = 0;     while(choice != 9)     {             printf("\n\t\t\t1. Add Node At The Beginning ");     printf("\n\t\t\t2. Insert Element in the Middle ");     printf("\n\t\t\t3. Append New Node "); ...

SWAP Two Values without using temporary variable

/**     Program Name: Swap Two Numbers     Description: This Program swaps two number, using XOR     Author:  Tauqirul Haque        */ #include <stdio.h> #include <conio.h> int main() {     int firstNumber, secondNumber;        printf("Enter The First Number :  ");     scanf("%d",&firstNumber);        printf("\nEnter The Second Number :  ");     scanf("%d",&secondNumber);        printf("\n\nNumbers Before Swapping :  %d  <-> %d \n",firstNumber, secondNumber);        firstNumber = firstNumber^secondNumber;     secondNumber = firstNumber^secondNumber;     firstNumber = firstNumber^secondNumber;        printf("\nNumbers After Swapping : ...

Linux User Survey

The most popular distro is Mandriva, with 17.9% of the respondents using it, followed by Suse, with 16.2%. The most popular application is Firefox, with 47.9% of the respondents using it, followed by OpenOffice, with 31.6% and Thunderbird, with 12.0%. Also appended below is a table with the break-down of the survey participants by country. Top Distros 1 Mandriva 17.9% 2 Suse 16.2% 3 Fedora 11.1% 4 Debian 7.7% 5 Red Hat 6.8% 6 Xandros 5.1% 7 Slackware 5.1% 8 Ubuntu 3.4% 9 Centos 3.4% 10 Mepis 3.4% 11 Gentoo 3.4% 12 Knoppix 2.6% 13 Linspire 1.7% 1...