Подбор шифра путем частотного анализа букв текста - C#

Узнай цену своей работы

Формулировка задачи:

Здравствуйте, в общем есть текст который шифруется с помощью цезаря, в полученном тексте надо посчитать общее количество символов сравнить с таблицей встречаемости символов в русском языке и провести замену, меня интересуют такие вопросы: 1)Алгоритм для подсчета символов я сделал, как лучше сделать вывод этого списка и возможно ли сделать чтобы он выводил символы с самого частого и по убыванию(думал отсортировать, но у меня они все в обычной стринге хранятся а если сделать массив то программа не будет работать нельзя сравнить char и string)
Листинг программы
  1. string n = textBox2.Text;
  2. double[] p = new double[n.Length];
  3. string q = "";
  4. bool f = true;
  5. for (int i = 0; i < n.Length; i++)
  6. {
  7. for (int j = 0; j < q.Length; j++)
  8. {
  9. if (n[i] == q[j])
  10. {
  11. f = false;
  12. p[j] += 1;
  13. }
  14. }
  15. if (f == true)
  16. { q += n[i]; p[i] = 1; }
  17. else f = true;
  18. }
(И я не утверждаю что он написан правильно) Что сделать можно? 2)Как реализовать саму подстановку символов (зашифрованный на нормальный)?

Решение задачи: «Подбор шифра путем частотного анализа букв текста»

textual
Листинг программы
  1. using System;
  2.  
  3. namespace ConsoleApplication2
  4. {
  5.     class Program
  6.     {
  7.         static void Main(string[] args)
  8.         {
  9.             string text = Console.ReadLine();
  10.             Encrypt(ref text);
  11.             Console.WriteLine(text);
  12.             Decrypt(ref text);
  13.             Console.WriteLine(text);
  14.             Console.ReadKey(true);
  15.         }
  16.  
  17.         static void Encrypt(ref string text)
  18.         {
  19.             const int SHIFT = 5; // Величина сдвига
  20.             string res = string.Empty;
  21.  
  22.             for (int i = 0; i < text.Length; i++)
  23.                 if (text[i] != ' ')
  24.                     res += (char)((int)text[i] + SHIFT);
  25.                 else
  26.                     res += text[i];
  27.             text = res;
  28.         }
  29.  
  30.         static void Decrypt(ref string text)
  31.         {
  32.             const int SHIFT = -5; // Величина сдвига
  33.             string res = string.Empty;
  34.  
  35.             for (int i = 0; i < text.Length; i++)
  36.                 if (text[i] != ' ')
  37.                     res += (char)((int)text[i] + SHIFT);
  38.                 else
  39.                     res += text[i];
  40.             text = res;
  41.         }
  42.     }
  43. }

ИИ поможет Вам:


  • решить любую задачу по программированию
  • объяснить код
  • расставить комментарии в коде
  • и т.д
Попробуйте бесплатно

Оцени полезность:

5   голосов , оценка 4.6 из 5

Нужна аналогичная работа?

Оформи быстрый заказ и узнай стоимость

Бесплатно
Оформите заказ и авторы начнут откликаться уже через 10 минут
Похожие ответы