Форум программистов, компьютерный форум CyberForum.ru

Шифрование методом "Диск Альберти" - C++

Восстановить пароль Регистрация
Другие темы раздела
C++ Программа-симулятор солнечной системы http://www.cyberforum.ru/cpp-beginners/thread1304298.html
Если нетрудно помогите нарисовать 8 планет (кругов) которые движутся навколо солнца я просто прошу нарисовать круги одинаковых размеров . Только чтобы эти планеты двигались по кругу. Мне это вопрос жизни после завтра курсач сдавать а вам это легкое дело помогите .
C++ Рассчитать расход топлива самолета Перед авиаперелётом на известное расстояние закупается топливо для самолёта. Топливо продаётся в ёмкостях заданного объёма, указана цена одной ёмкости. Также известен расход топлива самолёта. Требуется определить, хватит ли имеющейся суммы денег на закупку необходимого количества топлива. Топливо также может быть закуплено у иностранного поставщика, поэтому требуется узнать его стоимость в... http://www.cyberforum.ru/cpp-beginners/thread1304288.html
C++ Декодирование файла QP
Помогите с программой хотя бы чем то)) есть файл в котором записан Quoted-printable код.нужно декодировать с того файла бинарный изначальный файл и открыть его для просмотра.декодирована файла имя читать из входящего файла первой строки
Перевод Паскаль-С++: найти сумму элементов матрицы, которые по модулю больше единицы в каждом парном столбце C++
Помогите решить задачу, буду очень признателен. Определить сумму элементов матрицы, которые по модулю больше единицы в каждом парном столбце и количество таких элементов. Размер матрицы вводить с клавиатуры, а элементы разместить в памяти динамично. Добавлено через 14 минут Написал на Паскале - все работает, но на С++ никак не могу перенести( Program x; Uses crt; var b: array of...
C++ Перевод программы с Pascal на C++ http://www.cyberforum.ru/cpp-beginners/thread1304280.html
Имеется программа написанная на Pascal Program prim; uses Crt; var a:array of integer; t,min,x,y,u,i,j,k,l,m,n,cost:longint; b,c:array of integer; begin clrscr;
C++ Метод половинного деления Уравнение: sin x − 2.3x = 2.8 на интервале от (-π до π) подробнее

Показать сообщение отдельно
AlexeySarov
1 / 0 / 0
Регистрация: 06.12.2012
Сообщений: 46
18.11.2014, 19:27     Шифрование методом "Диск Альберти"
Написать приложение для преобразования файлов с открытым сообщением в файлы с зашифрованным сообщением методом "Диск Альберти".
У меня программа считывает текст из консоли, преобразует этот текст в зашифрованный и записывает в файл. А нужно, чтобы считывала не из консоли, а из файла, преобразовывала и записывала в новый файл.


C++
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
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
 
int main(int argc, char *argv[])
{
   size_t strLen, keyLen, i, k,k1,keyLen1;
   char str[250], key[250],key1[250];
   char codeStr1[250],codeStr[250];
 
   //system("chcp 1251");
   printf("Vvedite stroku: ");
   fgets(str, 249, stdin);
   printf("Vvedite kluch: ");
   fgets(key, 249, stdin);
   printf("Vvedite kluch2: ");
   fgets(key1, 249, stdin);
   strLen = strlen(str);
   keyLen = strlen(key);
   keyLen1 = strlen(key1);
   str[--strLen] = '\0';
   key[--keyLen] = '\0';
   key1[--keyLen1] = '\0';
   for (i = 0, k = 0; i < strLen; i++, k++)
   {
      if (k == (keyLen))
         k = 0;
      if (str[i] >= 'a' && str[i] <= 'z')
      {
          char sh;
          sh=(str[i] - 'a') % 26 + 'a';
            sh += ( key[k] - '0') % 10 + '0';
       codeStr1[i] = sh;
      }
   }
 
    for (i = 0, k1 = 0; i < strLen; i++, k1++)
   {
      if (k1 == (keyLen1))
         k1= 0;
      if (codeStr1[i] >= 'a' && codeStr1[i] <= 'z')
              {
          char sh1;
          sh1=(codeStr1[i] - 'a') % 26 + 'a';
            sh1 += ( key[k] - '0') % 10 + '0';
       codeStr[i] = sh1;
      }
    // codeStr[i] = (codeStr1[i] + key1[k1] - 2*'a') % 26 + 'a';
   }
 
   codeStr[strLen] = '\0';
   printf("3ashifrovannaya stroka\n%s\n", codeStr);
  // strcpy(str, codeStr);
     for (i = 0, k1 = 0; i < strLen; i++, k++)
   {
      if (k1 == (keyLen1))
         k1 = 0;
      if (codeStr1[i] >= 'a' && codeStr1[i] <= 'z')
         //str[i] = (codeStr1[i] - key1[k1] + 26) % 26 + 'a';
      {
        char sh1;
          sh1=codeStr1[i] % 26 + 'a';
            sh1 += ( key1[k1] + '0') % 10 + '0';
       codeStr[i] = sh1;
   } 
     }
 
   for (i = 0, k = 0; i < strLen; i++, k++)
   {
      if (k == (keyLen))
         k = 0;
      if (codeStr1[i] >= 'a' && codeStr1[i] <= 'z')
         //str[i] = (codeStr1[i] - key[k] + 26) % 26 + 'a';
         {
        char sh;
          sh=str[i] % 26 + 'a';
            sh += ( key[k] + '0') % 10 + '0';
       str[i] = sh;
   } 
 
   }
   printf("Rashifrovannaya stroka\n%s\n", str);
FILE *file=fopen("c:\\work/file.txt","w");
fprintf(file, "3ashifrovannaya stroka: %s, Rashifrovannaya stroka: %s",codeStr,str); 
fclose(file);
   system("pause");
   return 0;
}
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
Текущее время: 09:27. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru