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

С++ для начинающих

Войти
Регистрация
Восстановить пароль
 
Vlad_Bayran
0 / 0 / 0
Регистрация: 08.07.2015
Сообщений: 4
#1

Криптографический алгоритм "Квадрата Полибия" - C++

08.07.2015, 10:07. Просмотров 1394. Ответов 1
Метки нет (Все метки)

Вот смысл по простому написал, а записать на C++ Вообще не могу. Нет идей даже. Помогите пожалуйста. Как это записать в С++? Криптографический алгоритм "Квадрата Полибия"
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
08.07.2015, 10:07     Криптографический алгоритм "Квадрата Полибия"
Посмотрите здесь:

Класс "Криптографический метод защиты информации" - C++
В работе создается консольное приложение. Во всех вариантах требуется следующее: Описать класс, включающий заданные поля и методы...

Дешифровка. Метод: "Квадрат Полибия" - C++
Уважаемые форумчане! Зашифровать получилось, а с расшифровкой беда. Подскажите пожалуйста как это сделать. #include "stdafx.h" ...

Шифрование с использованием квадрата Полибия - C++
Здравствуйте! Помогите, пожалуйста, выполнить задание. Программу нужно сделать в Window Forms. Реализовать в программе шифрование и...

Осуществить "вращение" квадрата вокруг его центра - C++
вот есть не сложная задачка для Си: Осуществить "вращение" квадрата вокруг его центра. кто сможет сделать такое,буду очень...

Криптографический алгоритм с открытым ключом RSA - C++
Нужно зашифровать и расшифровать число с помощью криптографического алгоритма с открытым ключом RSA. http://ru.wikipedia.org/wiki/RSA ...

Добавил в "инклюды" regex, стал нерабочим алгоритм transform - C++
Доброго дня) В общем, может сталкивался кто - бредовая какая-то ошибка. В тексте программы есть алгоритм, преобразующий регистр...

Используя алгоритм сделать "реверс" элемента контейнера map - C++
map<string, int> msi; map = 1; map = 2; map<int, string> mis; Можно ли используя какой-нибудь стандартный алгоритм из std...

Быстрый подсчет A^B mod C или "Алгоритм русского крестьянина" - C++
Нужно максимально быстро посчитать A^B mod C. Написала алгоритм, казалось бы все хорошо, да вот только сижу я на e-olimp'e, делаю задачки,...

Алгоритм для реализации оператора "побитовое исключающее ИЛИ" - C++
Помогите пожалуйста не могу делать. Для заданных двух целых чисел предложите описание алгоритма для реализации оператора «побитовое...

Алгоритм ходов компьютера в карточной игре "Дурак" - C++
Здравствуйте. Помогите пожалуйста с реализацией алгоритма ходов компьютера. Я понимаю что должно быть что-то по типу просчета количесва...

Эмуляция планировщика процессов с использованием волокон. Алгоритм "случайный выбор" - C++
Прошу помочь.Есть готовая программа(готовый код).Хочу знать, что значит каждая строка кода. Для написания курсовой работы. using...

Не правильно работает алгоритм вычитания строк при перегрузке оператора "-"(минус) - C++
Написал алгоритм для перегрузки оператора "-" и в принципе все работает корректно, за исключением того, что после присваивания в строках 70...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
D_Gon
23 / 12 / 5
Регистрация: 09.07.2015
Сообщений: 47
10.07.2015, 13:09     Криптографический алгоритм "Квадрата Полибия" #2
Метод 1:
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
#include <iostream>
 
const char POLYBIUS[ 5 ][ 5 ] = { 
    { 'A', 'B', 'C' , 'D', 'E'},
    { 'F', 'G', 'H' , 'I', 'K'},
    { 'L', 'M', 'N' , 'O', 'P'},
    { 'Q', 'R', 'S' , 'T', 'U'},
    { 'V', 'W', 'X' , 'Y', 'Z'}
};
 
char encrypt( const char c ){
 
    for ( int i = 0; i < 5; ++i )
    for ( int j = 0; j < 5; ++j )
        if ( POLYBIUS[ i ][ j ] == c )
            return POLYBIUS[ ( i + 1 )%5 ][ j ];
}
 
char decrypt( const char c ){
 
    for ( int i = 0; i < 5; ++i )
    for ( int j = 0; j < 5; ++j )
        if ( POLYBIUS[ i ][ j ] == c )
            return POLYBIUS[ ( i + 4 )%5 ][ j ];
}
 
int main(){
 
    char c[] = "VLAD";
 
    for ( int i = 0; c[ i ] != '\0'; ++i )
        std::cout << encrypt( c[ i ] );
    std::cout << std::endl;
 
    std::cout << "------------------------" << std::endl;
    for ( int i = 0; c[ i ] != '\0'; ++i )
        std::cout << decrypt( encrypt( c[ i ] ) );
    std::cout << std::endl;
    
    return 0;
}
Добавлено через 47 минут
Метод 2:
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
89
90
91
#include <iostream>
 
const char POLYBIUS[ 5 ][ 5 ] = { 
    { 'A', 'B', 'C' , 'D', 'E'},
    { 'F', 'G', 'H' , 'I', 'K'},
    { 'L', 'M', 'N' , 'O', 'P'},
    { 'Q', 'R', 'S' , 'T', 'U'},
    { 'V', 'W', 'X' , 'Y', 'Z'}
};
 
void encrypt( char *c ){
 
    int size = -1;
    while ( c[ ++size ] != '\0' ){};
    
    int *x = new int[ size ];
    int *y = new int[ size ];
 
    for ( int k = 0; k < size; ++k ){
        
        for ( int i = 0; i < 5; ++i )
        for ( int j = 0; j < 5; ++j )
            if ( POLYBIUS[ i ][ j ] == c[ k ] ){
                x[ k ] = j;
                y[ k ] = i;
            }
    }
 
    int *z = new int[ 2*size ];
 
    for ( int k = 0; k < size; ++k )
        z[ k ] = x[ k ];
    for ( int k = size; k < 2*size; ++k )
        z[ k ] = y[ k - size ];
    
    for ( int k = 0; k < size; ++k ){
        x[ k ] = z[ k*2 ];
        y[ k ] = z[ k*2 + 1 ];
    }
 
    for ( int k = 0; k < size; ++k )
        c[ k ] = POLYBIUS[ y[ k ] ][ x[ k ] ];
 
    delete [] z;
    delete [] y;
    delete [] x;
}
 
void decrypt( char *c ){
 
    int size = -1;
    while ( c[ ++size ] != '\0' ){};
    
    int *z = new int[ 2*size ];
 
    for ( int k = 0; k < size; ++k ){
        
        for ( int i = 0; i < 5; ++i )
        for ( int j = 0; j < 5; ++j )
            if ( POLYBIUS[ i ][ j ] == c[ k ] ){
                z[ 2*k ] = j;
                z[ 2*k + 1 ] = i;
            }
    }
 
    int *x = new int[ size ];
    int *y = new int[ size ];
 
    for ( int k = 0; k < size; ++k )
        x[ k ] = z[ k ];
    for ( int k = size; k < 2*size; ++k )
        y[ k - size ] = z[ k ];
    
    for ( int k = 0; k < size; ++k )
        c[ k ] = POLYBIUS[ y[ k ] ][ x[ k ] ];
 
    delete [] y;
    delete [] x;
    delete [] z;
}
 
int main(){
 
    char c[] = "VLAD";
    encrypt( c );
    std::cout << c << std::endl;
    decrypt( c );
    std::cout << c << std::endl;
    
    return 0;
}
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru