Given a matrix and the task is to check matrix is involutory matrix or not.
Involutory Matrix: A matrix is said to be involutory matrix if matrix multiply by itself return the identity matrix. Involutory matrix is the matrix that is its own inverse. The matrix A is said to be involutory matrix if A * A = I. Where I is the identity matrix.
Examples:
Input : mat[N][N] = {{1, 0, 0},
                     {0, -1, 0},
                     {0, 0, -1}}
Output : Involutory Matrix
Input : mat[N][N] = {{1, 0, 0},
                     {0, 1, 0},
                     {0, 0, 1}} 
Output : Involutory Matrix
Implementation:
C++
| // Program to implement involutory matrix.#include <bits/stdc++.h>#define N 3usingnamespacestd;// Function for matrix multiplication.voidmultiply(intmat[][N], intres[][N]){    for(inti = 0; i < N; i++) {        for(intj = 0; j < N; j++) {            res[i][j] = 0;            for(intk = 0; k < N; k++)                res[i][j] += mat[i][k] * mat[k][j];        }    }}// Function to check involutory matrix.boolInvolutoryMatrix(intmat[N][N]){    intres[N][N];    // multiply function call.    multiply(mat, res);    for(inti = 0; i < N; i++) {        for(intj = 0; j < N; j++) {            if(i == j && res[i][j] != 1)                returnfalse;            if(i != j && res[i][j] != 0)                returnfalse;        }    }    returntrue;}// Driver function.intmain(){    intmat[N][N] = { { 1, 0, 0 },                      { 0, -1, 0 },                      { 0, 0, -1 } };    // Function call. If function return    // true then if part will execute otherwise    // else part will execute.    if(InvolutoryMatrix(mat))        cout << "Involutory Matrix";    else        cout << "Not Involutory Matrix";    return0;} | 
Java
| // Java  Program to implement // involutory matrix.importjava.io.*;classGFG {        staticintN = 3;        // Function for matrix multiplication.    staticvoidmultiply(intmat[][], intres[][])    {        for(inti = 0; i < N; i++) {            for(intj = 0; j < N; j++) {                res[i][j] = 0;                for(intk = 0; k < N; k++)                    res[i][j] += mat[i][k] * mat[k][j];            }        }    }        // Function to check involutory matrix.    staticbooleanInvolutoryMatrix(intmat[][])    {        intres[][] = newint[N][N];            // multiply function call.        multiply(mat, res);            for(inti = 0; i < N; i++) {            for(intj = 0; j < N; j++) {                if(i == j && res[i][j] != 1)                    returnfalse;                if(i != j && res[i][j] != 0)                    returnfalse;            }        }        returntrue;    }        // Driver function.    publicstaticvoidmain (String[] args)     {                intmat[][] = { { 1, 0, 0},                        { 0, -1, 0},                        { 0, 0, -1} };            // Function call. If function return        // true then if part will execute         // otherwise else part will execute.        if(InvolutoryMatrix(mat))            System.out.println ( "Involutory Matrix");        else            System.out.println ( "Not Involutory Matrix");                    }}// This code is contributed by vt_m | 
Python3
| # Program to implement involutory matrix.N =3;# Function for matrix multiplication.defmultiply(mat, res):    fori inrange(N):         forj inrange(N):            res[i][j] =0;            fork inrange(N):                res[i][j] +=mat[i][k] *mat[k][j];    returnres;# Function to check involutory matrix.defInvolutoryMatrix(mat):    res=[[0fori inrange(N)]             forj inrange(N)];    # multiply function call.    res =multiply(mat, res);    fori inrange(N):         forj inrange(N):            if(i ==j andres[i][j] !=1):                returnFalse;            if(i !=j andres[i][j] !=0):                returnFalse;    returnTrue;# Driver Codemat =[[1, 0, 0], [0, -1, 0], [0, 0, -1]];# Function call. If function # return true then if part # will execute otherwise# else part will execute.if(InvolutoryMatrix(mat)):    print("Involutory Matrix");else:    print("Not Involutory Matrix");# This code is contributed by mits | 
C#
| // C# Program to implement // involutory matrix.usingSystem;classGFG {        staticintN = 3;        // Function for matrix multiplication.    staticvoidmultiply(int[,]mat, int[,]res)    {        for(inti = 0; i < N; i++) {            for(intj = 0; j < N; j++) {                res[i,j] = 0;                for(intk = 0; k < N; k++)                    res[i,j] += mat[i,k] * mat[k,j];            }        }    }        // Function to check involutory matrix.    staticboolInvolutoryMatrix(int[,]mat)    {        int[,]res = newint[N,N];            // multiply function call.        multiply(mat, res);            for(inti = 0; i < N; i++) {            for(intj = 0; j < N; j++) {                if(i == j && res[i,j] != 1)                    returnfalse;                if(i != j && res[i,j] != 0)                    returnfalse;            }        }        returntrue;    }        // Driver function.    publicstaticvoidMain ()     {                int[,]mat = { { 1, 0, 0 },                        { 0, -1, 0 },                        { 0, 0, -1 } };            // Function call. If function return        // true then if part will execute         // otherwise else part will execute.        if(InvolutoryMatrix(mat))            Console.WriteLine( "Involutory Matrix");        else            Console.WriteLine( "Not Involutory Matrix");                    }}// This code is contributed by vt_m | 
PHP
| <?php// Program to implement // involutory matrix.$N= 3;// Function for matrix// multiplication.functionmultiply($mat, $res){    global$N;    for($i= 0; $i< $N; $i++)     {        for($j= 0; $j< $N; $j++)        {            $res[$i][$j] = 0;            for($k= 0; $k< $N; $k++)                $res[$i][$j] += $mat[$i][$k] *                                 $mat[$k][$j];        }    }    return$res;}// Function to check// involutory matrix.functionInvolutoryMatrix($mat){    global$N;    $res;    for($i= 0; $i< $N; $i++)        for($j= 0; $j< $N; $j++)            $res[$i][$j] = 0;    // multiply function call.    $res= multiply($mat, $res);    for($i= 0; $i< $N; $i++)     {        for($j= 0; $j< $N; $j++)        {            if($i== $j&&                $res[$i][$j] != 1)                returnfalse;            if($i!= $j&&                 $res[$i][$j] != 0)                returnfalse;        }    }    returntrue;}// Driver Code$mat= array(array(1, 0, 0),             array(0, -1, 0),             array(0, 0, -1));// Function call. If function // return true then if part // will execute otherwise// else part will execute.if(InvolutoryMatrix($mat))    echo"Involutory Matrix";else    echo"Not Involutory Matrix";// This code is contributed by mits?> | 
Javascript
| <script>// Javascript to implement involutory matrix. varN = 3;// Function for matrix multiplication.functionmultiply(mat, res){    for(vari = 0; i < N; i++)     {        for(varj = 0; j < N; j++)         {            res[i][j] = 0;            for(vark = 0; k < N; k++)                res[i][j] += mat[i][k] * mat[k][j];        }    }}// Function to check involutory matrix.functionInvolutoryMatrix(mat){    varres = Array(N).fill(0).map(        x => Array(N).fill(0));    // Multiply function call.    multiply(mat, res);    for(vari = 0; i < N; i++)     {        for(varj = 0; j < N; j++)         {            if(i == j && res[i][j] != 1)                returnfalse;            if(i != j && res[i][j] != 0)                returnfalse;        }    }    returntrue;}    // Driver codevarmat = [ [ 1, 0, 0 ],            [ 0, -1, 0 ],            [ 0, 0, -1 ] ];// Function call. If function return// true then if part will execute // otherwise else part will execute.if(InvolutoryMatrix(mat))    document.write("Involutory Matrix");else    document.write("Not Involutory Matrix");// This code is contributed by 29AjayKumar </script> | 
Involutory Matrix
Time Complexity: O(n3)
Auxiliary Space: O(n2), since n2 extra space has been taken.
Ready to dive in? Explore our Free Demo Content and join our DSA course, trusted by over 100,000 neveropen!


 
                                    








