namespace WhiteRabbit { using System; using System.Collections.Generic; using System.Diagnostics; using System.Linq; using System.Numerics; using System.Text; using Org.BouncyCastle.Crypto.Digests; /// /// Main class /// public static class Program { const string SourcePhrase = "poultry outwits ants"; const int MaxWordsInPhrase = 3; /// /// Main entry point /// public static void Main() { var stopwatch = new Stopwatch(); stopwatch.Start(); var processor = new StringsProcessor(Encoding.ASCII.GetBytes(SourcePhrase), MaxWordsInPhrase); var expectedHashes = new[] { "e4820b45d2277f3844eac66c903e84be", "23170acc097c24edb98fc5488ab033fe", "665e5bcb0c20062fe8abaaf4628bb154", }; var expectedHashesAsVectors = expectedHashes.Select(hash => new Vector(StringToByteArray(hash))).ToArray(); foreach (var result in AddHashes(processor.GeneratePhrases(ReadInput()))) { if (expectedHashesAsVectors.Contains(result.Item2)) { Console.WriteLine($"Found phrase: {Encoding.ASCII.GetString(result.Item1)} (spent {stopwatch.Elapsed})"); } } stopwatch.Stop(); Console.WriteLine($"Total time spent: {stopwatch.Elapsed}"); } // Code taken from http://stackoverflow.com/a/321404/831314 private static byte[] StringToByteArray(string hex) { return Enumerable.Range(0, hex.Length) .Where(x => x % 2 == 0) .Select(x => Convert.ToByte(hex.Substring(x, 2), 16)) .ToArray(); } private static IEnumerable>> AddHashes(IEnumerable input) { foreach (var line in input) { yield return Tuple.Create(line, ComputeHash(line)); } } private static Vector ComputeHash(byte[] input) { var digest = new MD5Digest(); digest.BlockUpdate(input, 0, input.Length); byte[] hash = new byte[16]; digest.DoFinal(hash, 0); return new Vector(hash); } private static IEnumerable ReadInput() { string line; while ((line = Console.ReadLine()) != null) { yield return Encoding.ASCII.GetBytes(line); } //System.Threading.Thread.Sleep(10000); } } }