-
Notifications
You must be signed in to change notification settings - Fork 1k
/
Copy pathHillCipher.java
158 lines (124 loc) · 4.51 KB
/
HillCipher.java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
/* This code is an implementation of Hill Cipher in Java.
It is a polygraphic substitution cipher. It forms a nxn
matrix of key and nx1 matrix(s) of the plaintext and then
multiplies the two matrices to obtains the matrix of ciphertext.*/
import java.util.*;
import java.lang.*;
public class HillCipher {
// This global variable defines the size of n
public static int size = 3;
/* This method forms the nxn matrix of keyword. The value of
n can be changed by setting the global vaiable size.*/
static void generateKeyMatrix(String key, int[][] keymatrix) {
int count = 0;
for(int i = 0; i < size; i++) {
for(int j = 0; j < size; j++) {
// Stores decimal value of ASCII
keymatrix[i][j] = key.charAt(count);
/* Here, a = 97, b = 98 and so on.
We want a = 0, b = 1 and so on. So,
we subtract 97.*/
keymatrix[i][j] -= 97;
count = count + 1;
}
}
}
/* This method forms the nx1 matrix of the plaintext. The value of n can be
changed by setting the global variable size.*/
static void generatePlaintextMatrix(String plaintext, int[][] plaintextmatrix) {
int count = 0;
for(int i = 0; i < size; i++) {
for(int j = 0; j < 1; j++) {
// Stores decimal value of ASCII
plaintextmatrix[i][j] = plaintext.charAt(count);
/* As we did above, we subtract 97 from the
decimal value to start indexing from 0.*/
plaintextmatrix[i][j] -= 97;
count = count + 1;
}
}
}
/* This function forms the nx1 ciphertext matrix. The matrix of decimal is then converted
to ascii value and combined and then returned.*/
static String generateCiphertextMatrix(String plaintext, String key, int[][] ciphertextmatrix) {
// Forming the keyword matrix
int[][] keymatrix = new int[size][size];
// Calling the keyord matrix function
generateKeyMatrix(key, keymatrix);
// Forming the plaintext matrix
int[][] plaintextmatrix = new int[size][1];
// Calling the plaintext matrix function
generatePlaintextMatrix(plaintext, plaintextmatrix);
/* Initializing the ciphertext matrix values to
zero. Otherwise, it would store garbage values.*/
for(int i = 0; i < size; i++) {
for(int j = 0; j < 1; j++) {
ciphertextmatrix[i][j] = 0;
}
}
/* Multiplying key matrix with plaintext matrix
and forming the ciphertext matrix. */
for(int i = 0; i < size; i++) {
for(int j = 0; j < 1; j++) {
for(int k = 0; k < size; k++) {
ciphertextmatrix[i][j] += keymatrix[i][k] * plaintextmatrix[k][j];
}
}
}
/* Taking mod 26 of obtained ciphertext values to
ensure they lie within the range [0-25].*/
for(int i = 0; i < size; i++) {
for(int j = 0; j < 1; j++) {
ciphertextmatrix[i][j] = ciphertextmatrix[i][j] % 26;
}
}
// Decalaring the ciphertext string
String cipher = new String("");
/* Since, we decremented 97 from the decimal values
of plaintext and key, we add back 97 to the ciphertext
values, in order to get proper ASCII.*/
for(int i = 0; i < size; i++) {
for(int j = 0; j < 1; j++) {
cipher += (char) (ciphertextmatrix[i][j] + 97);
}
}
// Return the encrypted plaintext
return cipher;
}
public static void main(String[] args) {
Scanner scan = new Scanner(System.in);
System.out.println("\n-----------------HILL CIPHER-----------------\n");
System.out.println("The length of plaintext must be same as size\n");
System.out.println("Current value of size is " + size + "\n");
// Taking plaintext as input from the user
System.out.print("Enter a plaintext of size " + size + ": ");
String plaintext = scan.nextLine();
// Checking if proper message is provided or not.
if(plaintext.length() != size) {
System.out.println("Enter a valid message.");
System.exit(0);
}
// Taking key as input from the user
System.out.print("Enter a keyword of size " + size*size + ": ");
String key = scan.nextLine();
// Checking if proper key is provided or not.
if(key.length() != size*size) {
System.out.println("Enter a valid key.");
System.exit(0);
}
scan.close();
int[][] ciphertextmatrix = new int[size][1];
String ciphertext = new String("");
// Calling the method to get the encrypted plaintext
ciphertext = generateCiphertextMatrix(plaintext, key, ciphertextmatrix);
System.out.println("The encrypted plaintext is: " + ciphertext);
}
}
/* Sample I/O:
-----------------HILL CIPHER-----------------
The length of plaintext must be same as size
Current value of size is 3
Enter a plaintext of size 3: pie
Enter a keyword of size 9: chocolate
The encrypted plaintext is: mem
*/