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

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

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

Осуществить "вращение" квадрата вокруг его центра C++
C++ Необработанное исключение в "0x00412b4a" в "kursovik.exe": 0xC0000005: Нарушение прав доступа при чтении "0x00000004".
Необработанное исключение в "0x00414558" в "467.exe": 0xC0000005: Нарушение прав доступа при чтении "0xabababbb" C++
C++ Необработанное исключение в "0x01082855" в "sort.exe": 0xC0000005: Нарушение прав доступа при записи "0xcccccccc"
C++ С++ консольное приложение win32, матерится на первое "pow" после "if", а на "system" говорит что неопределён.
C++ В массиве структур студент с полями "ИМЯ" "ВОЗРАСТ" "УСПЕВАЕМОСТЬ" выполнить сортировку по успеваемости по возрастанию
C++ Вставить пробел после каждого символа "." "," "!" или "?", если за этими символами не следует пробел
Шифрование с использованием квадрата Полибия C++

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

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
D_Gon
 Аватар для D_Gon
22 / 11 / 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;
}
Yandex
Объявления
10.07.2015, 13:09     Криптографический алгоритм "Квадрата Полибия"
Ответ Создать тему
Опции темы

Текущее время: 13:06. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru