С Новым годом! Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
0 / 0 / 0
Регистрация: 22.05.2019
Сообщений: 14

Дешифратор для Шифратора XOR

10.11.2019, 10:37. Показов 2040. Ответов 0

Студворк — интернет-сервис помощи студентам
Доброго времени суток. Вчера я сделал шифратор (метод XOR) и сегодня занялся дешифратором.
Но дешифратор:
1) не хочет воспринимать запись ключа с клавиатуры (cin>>key)
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
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
#include <iostream>
#include <fstream>
#include <string>
 
 
using namespace std;
 
int main()
{   
    char key[5] = {'d','i', 'm', 'o', 'n'};
 
    ///Чтение из Файла и запись в массив///
 
    string path = ("shifrtext.txt");
    ifstream shifrtext;
    shifrtext.open(path);
 
    if (!shifrtext)
    {
        cout << "Error 01! File not found!";
        system("pause");
    }
 
    char text01;
    int sybnum01 = 0;
 
    while (shifrtext.get(text01))
    {
        sybnum01++; //количество символов в тексте
    }
 
    shifrtext.close();
 
    cout << "Symbl Numb - " << sybnum01;
 
    ///Создание двомерного масссива///
 
    char** dvomas01 = new char*[2];
 
    for (int i = 0; i < 2; i++)
    {
        dvomas01[i] = new char[sybnum01];
    }
 
    ///Ввод текста в масссив///
 
    shifrtext.open(path);
 
    for (int j = 0; j < sybnum01; j++)
    {
        shifrtext.get(text01);
        dvomas01[0][j] = text01;
    }
 
    ///Ввод ключа в масссив///
 
    int sybnum02 = 0;
 
    for (int j = 0; j < sybnum01; j++)
    {
        dvomas01[1][j] = key[sybnum02];
        sybnum02++;
        if (sybnum02 == 5)
        {
            sybnum02 = sybnum02 - 5;
        }
    }
 
    ///Вывод получченого результата для теста работы программы///
 
    for (int i = 0; i < 2; i++)
    {
        cout << "\n";
        for (int j = 0; j < sybnum01; j++)
        {
            cout << dvomas01[i][j];
        }
    }
 
    ///Создание массива для перевода в числа///
 
    int** numdvomass = new int* [2];
 
    for (int i = 0; i < 2; i++)
    {                    //создание 2 2мерного 
        numdvomass[i] = new int[sybnum01];
    }
 
    cout << "\n"; //пропуск строчки для тестов программы
 
    ///Перевод текста в числа///
 
    for (int j = 0; j < sybnum01; j++)
    {
        //запись текста==numerik
        char num01 = dvomas01[0][j];
        unsigned char nn = num01;
 
        numdvomass[0][j] = nn;
 
    }
    for (int j = 0; j < sybnum01; j++)
    {
 
        char num01 = dvomas01[1][j];
        unsigned char nn = num01;
 
        numdvomass[1][j] = nn;
 
    }
 
    ///Вывод полученного результата для тестов///
 
    for (int i = 0; i < 2; i++)
    {
        cout << "\n";
        for (int j = 0; j < sybnum01; j++)
        {
            cout << numdvomass[i][j];
 
        }
    }
 
    cout << "\n" << "\n"; // пропуск строк для правильного отображения
 
    ///Процесс шифрование///
 
    int* shifrmass = new int[sybnum01];
 
    for (int i = 0; i < sybnum01; i++)
    {
 
        shifrmass[i] = (numdvomass[0][i] ^ numdvomass[1][i]);
        cout << shifrmass[i];
 
    }
 
    ///Запись результата в файл///
 
    ofstream shifrongon;
    shifrongon.open("shifrongonfile.txt");
 
    for (int i = 0; i < sybnum01; i++)
    {
        int shfrtext0023 = shifrmass[i];
        cout << shfrtext0023;
        shifrongon << shfrtext0023;
    }
    
    delete[] dvomas01;
    delete[] numdvomass;
    delete[] shifrmass;
    system("pause");
}
код дешифратора
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
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
#include <iostream>
#include <fstream>
#include <string>
 
using namespace std;
 
int main()
{
    ///Чтение из Файла и запись в массив///
 
    string path = ("shifrongonfile.txt");
    ifstream shifrtext;
    shifrtext.open(path);
 
    if (!shifrtext)
    {
        cout << "Error 01! File not found!";
        system("pause");
    }
 
    char text01;
    int sybnum01 = 0;
 
    while (shifrtext.get(text01))
    {
        sybnum01++; //количество символов в тексте
    }
 
    shifrtext.close();
 
    cout << "Symbl Numb - " << sybnum01;
 
    ///Создание двомерного масссива///
 
    char** dvomas01 = new char* [2];
 
    for (int i = 0; i < 2; i++)
    {
        dvomas01[i] = new char[sybnum01];
    }
 
    ///Ввод текста в масссив///
 
    shifrtext.open(path);
 
    for (int j = 0; j < sybnum01; j++)
    {
        shifrtext >> text01;
        dvomas01[0][j] = text01;
    }
 
    int sybnum02 = 0;
    char key023[5] = { 'd','i', 'm', 'o', 'n' };
 
    ///Ввод ключа в масссив///
 
    for (int j = 0; j < sybnum01; j++)
    {
        dvomas01[1][j] = key023[sybnum02];
        sybnum02++;
        if (sybnum02 == 5)
        {
            sybnum02 = sybnum02 - 5;
        }
    }
 
    ///Вывод получченого результата для теста работы программы///
 
    for (int i = 0; i < 2; i++)
    {
        cout << "\n";
        for (int j = 0; j < sybnum01; j++)
        {
            cout << dvomas01[i][j];
        }
    }
 
 
    ///Создание массива для перевода в числа///
 
    int** numdvomass = new int* [2];
 
    for (int i = 0; i < 2; i++)
    {
        numdvomass[i] = new int[sybnum01];
    }
 
    cout << "\n"; //пропуск строчки для тестов программы
 
    ///Перевод текста в числа///
 
    for (int j = 0; j < sybnum01; j++)
    {
        numdvomass[0][j] = dvomas01[0][j];
    }
    for (int j = 0; j < sybnum01; j++)
    {
 
        char num01 = dvomas01[1][j];
        unsigned char nn = num01;
 
        numdvomass[1][j] = nn;
 
    }
 
    ///Вывод полученного результата для тестов///
 
    for (int i = 0; i < 2; i++)
    {
        cout << "\n";
        for (int j = 0; j < sybnum01; j++)
        {
            cout << numdvomass[i][j];
 
        }
    }
 
 
    return 0;
}
Выводит он вот такую вещь

Symbl Numb - 35
11112378298771026177362628236272623
dimondimondimondimondimondimondimon

4949494950515556505756555549485054495555 515450545056505154505550545051
1001051091111101001051091111101001051091 1111010010510911111010010510911111010010 5109111110100105109111110

хотя должен просто переписывать число из файла и все.

Добавлено через 37 минут
если закинуть шифрованный текст в шифратор (для теста дешифровки) получиться UX\^\W^U]W\^Z^^V_\XYW__Y\\[^Y\S[[]]
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
10.11.2019, 10:37
Ответы с готовыми решениями:

Не могу сделать дешифратор, есть код шифратора
Здравствуйте, помогите плиз сделать дешифратор для этого кода, а то пробую но не выходит. #include &lt;stdio.h&gt; #include...

Оператор для xor шифрования
Разматриваю пример шифрования, возник детский вопрос ^ что делает этот оператор?

XOR шифрование для double
Здравствуйте, есть задание при помощи xor зашифровать и расшифровать массив double однобайтным ключом. Сложность возникла в том, как...

0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
10.11.2019, 10:37
Помогаю со студенческими работами здесь

Не получается создать нужный цикл для XOR шифрования
Здравствуйте! Я нашел задание с шифрованием через XOR, там было сказано, что нужно сделать так, чтоб символы сравнивались с ключем, который...

Построение многослойного персептрона для вычисления результатов логических операций (xor)
Сижу уже несколько дней. Подскажите что не так с кодом. Заранее спасибо #include &quot;stdafx.h&quot; #include &lt;iostream&gt; ...

дешифратор из шифратора
Сделал шифратор,теперь нужен шифратор по такому-же примеру &lt;form action=&quot;p8.php&quot; method=&quot;POST&quot;&gt; Введите текст для...

Написать код для шифратора
Шифрование должно производиться методом гаммирования с обратной связью по шифртексту. Добавлено через 1 минуту Желательно не для...

Помогите написать программу шифратора для двухразрядных десятичных чисел
Помогите написать программу шифратора для двухразрядных десятичных чисел.


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

Или воспользуйтесь поиском по форуму:
1
Ответ Создать тему
Новые блоги и статьи
Модель микоризы: классовый агентный подход
anaschu 02.01.2026
Раньше это было два гриба и бактерия. Теперь три гриба, растение. И на уровне агентов добавится между грибами или бактериями взаимодействий. До того я пробовал подход через многомерные массивы,. . .
Учёным и волонтёрам проекта «Einstein@home» удалось обнаружить четыре гамма-лучевых пульсара в джете Млечного Пути
Programma_Boinc 01.01.2026
Учёным и волонтёрам проекта «Einstein@home» удалось обнаружить четыре гамма-лучевых пульсара в джете Млечного Пути Сочетание глобально распределённой вычислительной мощности и инновационных. . .
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост.
Programma_Boinc 28.12.2025
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост. Налог на собак: https:/ / **********/ gallery/ V06K53e Финансовый отчет в Excel: https:/ / **********/ gallery/ bKBkQFf Пост отсюда. . .
Кто-нибудь знает, где можно бесплатно получить настольный компьютер или ноутбук? США.
Programma_Boinc 26.12.2025
Нашел на реддите интересную статью под названием Anyone know where to get a free Desktop or Laptop? Ниже её машинный перевод. После долгих разбирательств я наконец-то вернула себе. . .
Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы, точка.
Programma_Boinc 23.12.2025
Рецензия / Мнение/ Перевод Нашел на реддите интересную статью под названием The Thinkpad X220 Tablet is the best budget school laptop period . Ниже её машинный перевод. Thinkpad X220 Tablet —. . .
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Как объединить две одинаковые БД Access с разными данными
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru