#include<iostream> // Allows input output operations
#include <iomanip>
#include<math.h>
using namespace std;
#define N 200
#define ARRAY_SIZE (N*N)
#define M 100
// Mapping is defined for [a-z] , [A-Z] , [0-9]
// {'A','6'} maps A to 6
//
char map[ M] [ 2 ] =
{
{ 'A' ,'6' } , { 'B' ,'b' } , { 'C' ,'c' } , { 'D' ,'d' } , { 'E' ,'2' } , { 'F' ,'1' } , { 'G' ,'g' } , { 'H' ,'h' } , { 'I' ,'9' } , { 'J' ,'j' } , { 'K' ,'k' } ,
{ 'L' ,'S' } , { 'M' ,'m' } , { 'N' ,'n' } , { 'O' ,'o' } , { 'P' ,'p' } , { 'Q' ,'q' } , { 'R' ,'r' } , { 'S' ,'s' } , { 'T' ,'t' } , { 'U' ,'u' } , { 'V' ,'v' } ,
{ 'W' ,'w' } , { 'X' ,'x' } , { 'Y' ,'y' } , { 'Z' ,'z' } , { 'a' ,'A' } , { 'b' ,'B' } , { 'c' ,'C' } , { 'd' ,'D' } , { 'e' ,'E' } , { 'f' ,'F' } , { 'g' ,'G' } ,
{ 'h' ,'H' } , { 'i' ,'I' } , { 'j' ,'J' } , { 'k' ,'K' } , { 'l' ,'L' } , { 'm' ,'M' } , { 'n' ,'N' } , { 'o' ,'O' } , { 'p' ,'P' } , { 'q' ,'Q' } , { 'r' ,'R' } ,
{ 's' ,'l' } , { 't' ,'T' } , { 'u' ,'U' } , { 'v' ,'V' } , { 'w' ,'W' } , { 'x' ,'X' } , { 'y' ,'Y' } , { 'z' ,'Z' } , { '0' ,'i' } , { '1' ,'8' } , { '2' ,'7' } ,
{ '3' ,'a' } , { '4' ,'5' } , { '5' ,'4' } , { '6' ,'3' } , { '7' ,'e' } , { '8' ,'f' } , { '9' ,'0' }
} ;
// Define functionality for the following functions
// And call them in main()
/*For calculating Determinant of the Matrix */
/*******************************************************************************
* Function Name : determinant
* Description : Given a square matrix array[][]. Calculates determinant.
* Input : array,order
* Output : Determinant
* Return : determinant value(type float)
* Example : Order = 2
Array [ 3 2 ] -> Returns 5.3000
[ 2 3.1 ]
*******************************************************************************/
float determinant( float array[ N] [ N] ,float order)
{
float sum= 0 ,c;
for ( int j= 1 ; j<= order; j++ )
{
for ( int i= j+ 1 ; i<= order; i++ )
{
c= ( array[ i] [ j] ) / array[ j] [ j] ;
for ( int k= j; k<= order; k++ )
{
array[ i] [ k] = array[ i] [ k] - c* array[ j] [ k] ;
}
}
}
for ( int l= 1 ; l<= order; l++ )
{
sum= sum+ array[ l] [ l] ;
}
return sum;
}
/*******************************************************************************
* Function Name : inverse
* Description : Given a square matrix array[][]. Calculates inverse_array.
* Input : array,order
* Output : inv
* Return : None
* Example : Order = 2
Array [ 3 2 ] -> inv [ (3/5) (-2/5) ]
[ 2 3 ] [ (-2/5) (3/5) ]
*******************************************************************************/
void inverse( float inv[ N] [ N] ,float array[ N] [ N] ,float order)
{
float c[ N] [ N] ;
int l,p,h,k,i,j;
for ( l= 0 ; l< order; l++ )
{
for ( p= 0 ; p< order; p++ )
{
h= 0 ,k= 0 ;
for ( i= 0 ; i< order; i++ )
{
if ( i== l)
continue ;
for ( j= 0 ; j< order; j++ )
{
if ( j== p)
continue ;
c[ h] [ k] = array[ i] [ j] ;
k++ ;
if ( k= ( order- 1 ) )
{
h++ ;
k= 0 ;
}
}
}
inv[ p] [ l] = ( pow ( - 1 ,l+ p) * determinant( c,order- 1 ) ) / determinant( array,order) ;
}
}
}
/*******************************************************************************
* Function Name : array_map
* Description : Maps plain_text_zero_padded to mapped_array using map array
* Input : plain_text_zero_padded
* Output : mapped_array
* Return : None
* Example : plain_text_zero_padded "ABCDE00" -> mapped_array "abcd2ii"
*******************************************************************************/
void array_map( char mapped_array[ ARRAY_SIZE] , char plain_text_zero_padded[ ARRAY_SIZE] )
{
for ( int i= 0 ; i< ARRAY_SIZE; i++ )
{
for ( int j= 0 ; j< M; j++ )
{
if ( plain_text_zero_padded[ i] ! = map[ j] [ 0 ] )
continue ;
else
{
mapped_array[ i] = map[ j] [ 1 ] ;
break ;
}
}
}
/*******************************************************************************
* Function Name : inv_array_map
* Description : Maps inv_mapped_array to decrypt_plain_text_zero_padded using map array
* Input : inv_mapped_array
* Output : decrypt_plain_text_zero_padded
* Return : None
* Example : inv_mapped_array "abcd2ii" -> decrypt_plain_text_zero_padded "ABCDE00"
*******************************************************************************/
void inv_array_map( char inv_mapped_array[ ARRAY_SIZE] , char decrypt_plain_text_zero_padded[ ARRAY_SIZE] )
{
for ( int i= 0 ; i< ARRAY_SIZE; i++ )
{
for ( int j= 0 ; j< M; j++ )
{
if ( inv_mapped_array[ i] ! = map[ j] [ 1 ] )
continue ;
else
{
decrypt_plain_text_zero_padded[ i] = map[ j] [ 0 ] ;
break ;
}
}
}
}
// Donot modify the functions below(upto main)
void keygen( float key[ N] [ N] , int marker)
{
int i,j;
for ( i= 0 ; i< marker; i++ ) {
for ( j= 0 ; j< marker; j++ ) {
if ( i ! = j)
key[ i] [ j] = marker;
else
key[ i] [ j] = marker + 1 ;
}
}
}
void print( char c[ N] [ N] , int row, int col)
{
int i,j;
for ( i= 0 ; i< row; i++ ) {
for ( j= 0 ; j< col; j++ ) {
cout << c[ i] [ j] << " " ;
}
cout << endl;
}
}
void print( float f[ N] [ N] , int row, int col)
{
int i,j;
for ( i= 0 ; i< row; i++ ) {
for ( j= 0 ; j< col; j++ ) {
std:: cout << std:: fixed << std:: setprecision ( 3 ) << setw( 15 ) << f[ i] [ j] ;
}
cout << endl;
}
}
void compare( char plain_text[ N] ,char decrypt_plain_text[ N] , int length_of_input)
{
int loi;
for ( loi = 0 ; ( plain_text[ loi] == decrypt_plain_text[ loi] && plain_text[ loi] ) ; loi++ ) ;
if ( loi == length_of_input)
cout << "SUCCESS" << endl;
}
int main( ) {
/*********** DO NOT CHANGE VARIABLE NAMES ************/
char plain_text[ ARRAY_SIZE] ;
int marker;
float key[ N] [ N] ;
float cipher_text[ N] [ N] ;
float invkey[ N] [ N] ;
char decrypt_plain_text[ ARRAY_SIZE] ;
char inv_mapped_array[ ARRAY_SIZE] ;
/***************Get User Input***************/
cout << "Enter the plain text" << endl;
cin >> plain_text;
cout << "Enter the marker" << endl;
cin >> marker;
// Creating a key matrix of size (marker x marker)
keygen( key,marker) ;
/***************End User Input***************/
/*---------------------------------------------*/
// Please add your code here
int length_of_input;
for ( length_of_input = 0 ; plain_text[ length_of_input] ; length_of_input++ ) ;
int r;
r= length_of_input% marker;
for ( int a= 0 ; a< ( length_of_input+ marker- r) ; a++ )
{
if ( a< length_of_input)
{
plain_text_zero_padded[ a] = plain_text[ a] ;
}
else {
plain_text_zero_padded[ a] = 0 ;
}
}
void array_map( mapped_array,plain_text_zero_padded) ;
char mapped[ ARRAY_SIZE] [ N] ;
int z= 0 ;
for ( int e= 0 ; e< ( length_of_input/ marker) + 1 ; e++ )
{
for ( int f= 0 ; f< marker; f++ )
{
mapped[ e] [ f] = mapped_array[ z] ;
z++ ;
}
}
for ( int b= 0 ; b< ( length_of_input/ marker) + 1 ; b++ )
{
for ( int c= 0 ; c< marker; c++ )
{
cipher_text[ b] [ c] = 0 ;
for ( int d= 0 ; d< marker; d++ )
cipher_text[ b] [ c] + = mapped[ b] [ d] * key[ d] [ c] ;
}
}
char rev_mapped[ ARRAY_SIZE] [ N] ;
void inverse( invkey,key,marker) ;
for ( int o= 0 ; o< ( length_of_input/ marker) + 1 ; o++ )
{
for ( int p= 0 ; p< marker; p++ )
{
rev_mapped[ o] [ p] = 0 ;
for ( int q= 0 ; q< marker; q++ )
rev_mapped[ o] [ p] + = cipher_text[ o] [ q] * invkey[ q] [ p] ;
}
}
int y= 0 ;
for ( int e= 0 ; e< ( length_of_input/ marker) + 1 ; e++ )
{
for ( int f= 0 ; f< marker; f++ )
{
inv_mapped_array[ y] = rev_mapped[ e] [ f] ;
y++ ;
}
}
void inv_array_map( inv_mapped_array, decrypt_plain_text_zero_padded) ;
/*---------------------------------------------*/
// Donot modify
//
cout << "Plain Text entered" << endl;
cout << plain_text<< "\n " ;
cout << "Key Used" << endl;
print( key,marker,marker) ;
cout << "Cipher Text " << endl;
print( cipher_text,( int ) ceil ( ( float ) length_of_input/ marker) ,marker) ;
cout << "Key Inverse" << endl;
print( invkey,marker,marker) ;
cout << "Decrypted Text" << endl;
cout << decrypt_plain_text << "\n " ;
compare( plain_text,decrypt_plain_text,length_of_input) ;
return 0 ;
}
#include<iostream> 	// Allows input output operations
#include <iomanip>
#include<math.h>

using namespace std;

#define N           200
#define ARRAY_SIZE  (N*N)
#define M           100 

//  Mapping is defined for [a-z] , [A-Z] , [0-9]
//  {'A','6'} maps A to 6 
//
char map[M][2] = 
{
{'A','6'}, {'B','b'}, {'C','c'}, {'D','d'}, {'E','2'}, {'F','1'}, {'G','g'}, {'H','h'}, {'I','9'}, {'J','j'}, {'K','k'}, 
{'L','S'}, {'M','m'}, {'N','n'}, {'O','o'}, {'P','p'}, {'Q','q'}, {'R','r'}, {'S','s'}, {'T','t'}, {'U','u'}, {'V','v'}, 
{'W','w'}, {'X','x'}, {'Y','y'}, {'Z','z'}, {'a','A'}, {'b','B'}, {'c','C'}, {'d','D'}, {'e','E'}, {'f','F'}, {'g','G'}, 
{'h','H'}, {'i','I'}, {'j','J'}, {'k','K'}, {'l','L'}, {'m','M'}, {'n','N'}, {'o','O'}, {'p','P'}, {'q','Q'}, {'r','R'}, 
{'s','l'}, {'t','T'}, {'u','U'}, {'v','V'}, {'w','W'}, {'x','X'}, {'y','Y'}, {'z','Z'}, {'0','i'}, {'1','8'}, {'2','7'}, 
{'3','a'}, {'4','5'}, {'5','4'}, {'6','3'}, {'7','e'}, {'8','f'}, {'9','0'}
};


// Define functionality for the following functions
// And call them in main()

/*For calculating Determinant of the Matrix */

/*******************************************************************************
* Function Name  : determinant
* Description    : Given a square matrix array[][]. Calculates determinant. 
* Input          : array,order
* Output         : Determinant  
* Return         : determinant value(type float)
* Example        : Order = 2 
Array [ 3 2   ]   -> Returns 5.3000
      [ 2 3.1 ]     

 *******************************************************************************/
float determinant(float array[N][N],float order)
{
float sum=0,c;
for(int j=1;j<=order;j++)
{
	for(int i=j+1;i<=order;i++)
	{
		c=(array[i][j])/array[j][j];
		for(int k=j;k<=order;k++)
		{
			array[i][k]=array[i][k]-c*array[j][k];
					}
	}
}
for(int l=1;l<=order;l++)
{
sum=sum+array[l][l];
}
return sum;
}

/*******************************************************************************
* Function Name  : inverse
* Description    : Given a square matrix array[][]. Calculates inverse_array. 
* Input          : array,order
* Output         : inv
* Return         : None
* Example        : Order = 2 

Array [ 3 2 ]   -> inv [  (3/5)   (-2/5)  ]
      [ 2 3 ]          [  (-2/5)  (3/5)   ]
 
*******************************************************************************/


void inverse(float inv[N][N],float array[N][N],float order)
{
float c[N][N];
int l,p,h,k,i,j;
for(l=0;l<order;l++)
{
	for(p=0;p<order;p++)
	{
		h=0,k=0;
		for(i=0;i<order;i++)
		{
			if(i==l)
			continue;
			for(j=0;j<order;j++)
			{
				if(j==p)
				continue;
				c[h][k]=array[i][j];
				k++;
				if(k=(order-1))
				{
					h++;
					k=0;
				}
			}
					}
					
					inv[p][l]=(pow(-1,l+p)*determinant(c,order-1))/determinant(array,order);
					
	}
}
}

/*******************************************************************************
* Function Name  : array_map
* Description    : Maps plain_text_zero_padded to mapped_array using map array 
* Input          : plain_text_zero_padded
* Output         : mapped_array
* Return         : None
* Example        : plain_text_zero_padded "ABCDE00" -> mapped_array "abcd2ii" 
*******************************************************************************/


void array_map(char mapped_array[ARRAY_SIZE], char plain_text_zero_padded[ARRAY_SIZE])
{
	for(int i=0;i<ARRAY_SIZE;i++)
	{
	for(int j=0;j<M;j++)
	{
		if(plain_text_zero_padded[i]!=map[j][0])
		continue;
		else
		{
			mapped_array[i]=map[j][1];
			break;
		}
	}
	

}



/*******************************************************************************
* Function Name  : inv_array_map
* Description    : Maps inv_mapped_array to decrypt_plain_text_zero_padded using map array 
* Input          : inv_mapped_array
* Output         : decrypt_plain_text_zero_padded
* Return         : None
* Example        : inv_mapped_array "abcd2ii" -> decrypt_plain_text_zero_padded "ABCDE00" 
*******************************************************************************/

void inv_array_map(char inv_mapped_array[ARRAY_SIZE], char decrypt_plain_text_zero_padded[ARRAY_SIZE])
{
for(int i=0;i<ARRAY_SIZE;i++)
{
	for(int j=0;j<M;j++)
	{
		if(inv_mapped_array[i]!=map[j][1])
continue;
else
{
	decrypt_plain_text_zero_padded[i]=map[j][0];
	break;
	
	}
		}
}
}


// Donot modify the functions below(upto main) 

void keygen(float key[N][N], int marker)
{
  int i,j;

 for(i=0;i<marker;i++){  
    for(j=0;j<marker;j++){
      if(i != j)
        key[i][j] = marker;
      else
        key[i][j] = marker + 1;
    }
  }

}

void print(char c[N][N], int row, int col)
{

  int i,j;

  for(i=0;i<row;i++){  
    for(j=0;j<col;j++){
     cout << c[i][j]<< " ";
    }
  cout << endl;
  }

}

void print(float f[N][N], int row, int col)
{

  int i,j;

  for(i=0;i<row;i++){  
    for(j=0;j<col;j++){
     std::cout << std::fixed << std::setprecision(3) << setw(15) << f[i][j] ;
    }
  cout << endl;
  }

}

void compare(char plain_text[N],char decrypt_plain_text[N], int length_of_input)
{
  int loi;
  for (loi = 0;(plain_text[loi] == decrypt_plain_text[loi] && plain_text[loi]);loi++);
  if(loi == length_of_input)
    cout << "SUCCESS"<<endl;
}

int main() {

	/*********** DO NOT CHANGE VARIABLE NAMES ************/
        char plain_text[ARRAY_SIZE];
        int marker;

        float key[N][N];

        float cipher_text[N][N];
        float invkey[N][N];
        char decrypt_plain_text[ARRAY_SIZE];
        char inv_mapped_array[ARRAY_SIZE];

	/***************Get User Input***************/


        cout << "Enter the plain text" << endl;
        cin >> plain_text;

        cout << "Enter the marker" << endl;
        cin >> marker;
        
        // Creating a key matrix of size (marker x marker)
        keygen(key,marker);


        /***************End User Input***************/	
	
	
	/*---------------------------------------------*/

	// Please add your code here 
 int length_of_input;
        for (length_of_input = 0;plain_text[length_of_input];length_of_input++);
       int r;
       r=length_of_input%marker;
       for(int a=0;a<(length_of_input+marker-r);a++)
       {
       	if (a<length_of_input)
       	{
		   plain_text_zero_padded[a]=plain_text[a];
		   }
		   else{
		   
       	plain_text_zero_padded[a]=0;
       }
	   }
void array_map(mapped_array,plain_text_zero_padded);
char mapped[ARRAY_SIZE][N];
int z=0;
for( int e=0;e<(length_of_input/marker)+1;e++)
{
	for(int f=0;f<marker;f++)
	{
		mapped[e][f]=mapped_array[z];
		z++;
	}
}



for (int b=0;b<(length_of_input/marker)+1;b++)
{
	for(int c=0;c<marker;c++)
	{
		cipher_text[b][c]=0;
		for(int d=0;d<marker;d++)
		cipher_text[b][c]+=mapped[b][d]*key[d][c];
	}
}
char rev_mapped[ARRAY_SIZE][N];
void inverse(invkey,key,marker);
for(int o=0;o<(length_of_input/marker)+1;o++)
{
	for(int p=0;p<marker;p++)
	{
		rev_mapped[o][p]=0;
		for(int q=0;q<marker;q++)
		rev_mapped[o][p]+=cipher_text[o][q]*invkey[q][p];
	}
}
int y=0;
for( int e=0;e<(length_of_input/marker)+1;e++)
{
	for(int f=0;f<marker;f++)
	{
		inv_mapped_array[y]=rev_mapped[e][f];
		y++;
	}
}
void inv_array_map( inv_mapped_array,  decrypt_plain_text_zero_padded);











        /*---------------------------------------------*/
        //  Donot modify 
        //
       
        cout << "Plain Text entered" << endl;
        cout << plain_text<< "\n";
       
        cout << "Key Used" << endl;
        print(key,marker,marker);
        
        cout << "Cipher Text " << endl;
        print(cipher_text,(int)ceil((float)length_of_input/marker),marker);

        cout << "Key Inverse" << endl;
        print(invkey,marker,marker);
        
        cout << "Decrypted Text" << endl;
        cout << decrypt_plain_text << "\n";

        compare(plain_text,decrypt_plain_text,length_of_input);
            
	return 0;
}


