summaryrefslogtreecommitdiffstats
path: root/challenge/c04.go
diff options
context:
space:
mode:
authorrsiddharth <s@ricketyspace.net>2020-11-25 21:27:51 -0500
committerrsiddharth <s@ricketyspace.net>2020-11-25 21:28:03 -0500
commita78d0e51eab40771e09c283eebb8ee72a00e4620 (patch)
tree6e59b2c424561d90500f4aa05f020cbce80b25f6 /challenge/c04.go
parent85ced08016009189edd648f8471515cc52b1abd2 (diff)
challenge: c04: add output
And move C4 function to the top.
Diffstat (limited to 'challenge/c04.go')
-rw-r--r--challenge/c04.go63
1 files changed, 35 insertions, 28 deletions
diff --git a/challenge/c04.go b/challenge/c04.go
index e075133..028a0f8 100644
--- a/challenge/c04.go
+++ b/challenge/c04.go
@@ -8,6 +8,41 @@ import (
"ricketyspace.net/cryptopals/lib"
)
+func C4() {
+ i, k, ds, scr := 0, byte(0), "", 100.0
+ for j := 0; j < len(blobs); j++ {
+ c, as, s := lib.XORCrackSingleKey(blobs[j])
+ if s < scr {
+ i = j
+ k = c
+ ds = as
+ scr = s
+ }
+ }
+ fmt.Printf("Blob encrypted with a single character: %v\n", blobs[i])
+ fmt.Printf("Key is '%c'\n", k)
+ fmt.Printf("Decrypted string: '%v' (Score: %v)\n", ds, scr)
+}
+
+// Output:
+//
+// Blob encrypted with a single character: 7b5a4215415d544115415d5015455447414c155c46155f4058455c5b523f
+// Key is '5'
+// Decrypted string: 'Now that the party is jumping
+// ' (Score: 0.05999999999999994)
+
+func init() {
+ for i, j := 1, 0; i < len(blob); i++ {
+ if blob[i] == '\n' {
+ j += 1
+ i += 1
+ }
+ blobs[j] += string(blob[i])
+ }
+}
+
+var blobs = make([]string, 327)
+
const blob = `
0e3647e8592d35514a081243582536ed3de6734059001e3f535ce6271032
334b041de124f73c18011a50e608097ac308ecee501337ec3e100854201d
@@ -336,31 +371,3 @@ e03555453d1e31775f37331823164c341c09e310463438481019fb0b12fa
41053f5cef5f6f56e4f5410a5407281600200b2649460a2e3a3c38492a0c
4c071a57e9356ee415103c5c53e254063f2019340969e30a2e381d5b2555
32042f46431d2c44607934ed180c1028136a5f2b26092e3b2c4e2930585a`
-
-var blobs = make([]string, 327)
-
-func init() {
- for i, j := 1, 0; i < len(blob); i++ {
- if blob[i] == '\n' {
- j += 1
- i += 1
- }
- blobs[j] += string(blob[i])
- }
-}
-
-func C4() {
- i, k, ds, scr := 0, byte(0), "", 100.0
- for j := 0; j < len(blobs); j++ {
- c, as, s := lib.XORCrackSingleKey(blobs[j])
- if s < scr {
- i = j
- k = c
- ds = as
- scr = s
- }
- }
- fmt.Printf("Blob encrypted with a single character: %v\n", blobs[i])
- fmt.Printf("Key is '%c'\n", k)
- fmt.Printf("Decrypted string: '%v' (Score: %v)\n", ds, scr)
-}