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

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

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Дана строка. Вычеркнуть из нее все русские заглавные буквы http://www.cyberforum.ru/cpp-beginners/thread1495171.html
Помогите составить код задачи: дана строка. Вычеркнуть из нее все русские заглавные буквы.
C++ В прямоугольной матрице заменить элементы каждого столбца на сумму элементов этого столбца Решить задачу: в прямоугольной матрице заменить элементы каждого столбца на сумму элементов этого столбца. http://www.cyberforum.ru/cpp-beginners/thread1495166.html
C++ Заполнить квадратную матрицу по правилу «шахматная доска»
Помогите заполнить квадратную матрицу порядка N по следующему правилу: «шахматная доска» - чередовать в каждой строке числа 0 и 1, причем одна строка начинается с 0, другая – с 1, и т.д.
Как реализовать криптографический алгоритм "Квадрата Полибия" на C++ C++
Ну это для простоты пример . Я понимаю, но не могу записать на C++
C++ Поменять порядок следования символов строки на обратный http://www.cyberforum.ru/cpp-beginners/thread1495147.html
Всем привет помогите пожалуйста.Решить задачу: поменять порядок следования символов данной строки на обратный. Например, для строки «Мама мыла раму.» получаем ответ «.умар алым амаМ».
C++ Найти произведение элементов массива, результат умножения цифр которых больше заданного К Помогите, пожалуйста, найти произведение тех элементов массива, содержащего натуральные числа, произведение цифр которых больше заданного K. подробнее

Показать сообщение отдельно
D_Gon
24 / 13 / 5
Регистрация: 09.07.2015
Сообщений: 47
10.07.2015, 13:09
Метод 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;
}
2
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru