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

Шифр Альберти - C++

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Не правильно выводит значение (if, else) http://www.cyberforum.ru/cpp-beginners/thread359500.html
Неправильно выводит Плату за стоянку, помогите с условием #include "stdafx.h" #include<iostream> using namespace std; double calcCharges(double x) { double charge; if ( x <= 3 )
C++ Веб-браузер Решил написать веб-браузер но, знания о C++ слишком малы. помогите мне надо для своей ОС. http://www.cyberforum.ru/cpp-beginners/thread359499.html
C++ Небольшое исправление (2)
Собственно нужно при нажатии кнопки " ' " нужно вывести на экран содержимое первого окна в новом окне с кнопкой ОК. Сама кнопка работает, только не выводит текста, выводит ошибку преобразования string в char. Прошу помощи. #include <windows.h> #include <string> using namespace std; LRESULT CALLBACK WindowProcedure (HWND,UINT,WPARAM,LPARAM); char szClassName ="Мой класс оконный"; int...
Очень нужно объяснение C++
в универе дали вот такую функцию y=exp(-0.1*X)-{-}^2-cos(4*X)^4 надо написать код чтобы visual c++ могла подсчитать эту функцию Объясните пожалуйста как)))
C++ Разобрать код простых чисел через массивы http://www.cyberforum.ru/cpp-beginners/thread359468.html
to idetify if the given K is prime or not. Prime number is the number that can be divided by 1 and by itself ONLY. If given number is prime output "YES",otherwise ouput "NO". Input: Only one line with n number.(1<=N=<1000) Output: Only one line with "YES" or "NO". Sample input 1: 4
C++ Как убрать период у радиан? Есть аргумент - вещественное число. Аргумент передается в функцию синуса(радиан). Стандартная функция спокойно убирает период. Написал функцию с помощью рекуррентного соотношения, но не могу убрать период. По сути аргумент нужно делить на Пи(период) и записывать остаток. Но как взять остаток от вещественных чисел? Может перевести с помощью static_cast? Но у меня не вышло. подробнее

Показать сообщение отдельно
talis
791 / 543 / 37
Регистрация: 11.05.2010
Сообщений: 1,298
Записей в блоге: 1
02.10.2011, 21:21     Шифр Альберти
Вот, набросал утилитку

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
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
#include <iostream>
#include <fstream>
#include <vector>
#include <string>
#include <algorithm>
 
using namespace std;
 
/* сгенерировать случайный шифроалфавит */
string generate_alphabet()
{
    string alphabet = " !\"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\\]^_`abcdefghijklmnopqrstuvwxyz{|}~";
 
    // это несколько.. некрасиво
    /*for( char i = ' '; i <= '~'; i++ )
       alphabet.append( 1, i );*/
 
    random_shuffle( alphabet.begin(), alphabet.end() );
 
    return alphabet;
}
 
/* загрузить набор шифроалфавитов из файла file_name,
   добавив их в конец набора шифроалфавитов sequence */
bool load_alphabets( const string &file_name, vector<string> &sequence )
{
    string buffer;
 
    ifstream fs( file_name );
 
    if( !fs.is_open() )
       return false;
 
    fs >> buffer;
 
    if( buffer != "{alberti_alphabets}" )
        return false;
 
    while( !fs.eof() )
    {
        getline( fs, buffer );
 
        if( buffer.length() )
           sequence.push_back( buffer );
    }
 
    fs.close();
    return true;
}
 
/* сохранить набор шифроалфавитов sequece в файл file_name */
bool save_alphabets( const string &file_name, const vector<string> &sequence )
{
    ofstream fs( file_name );
 
    if( !fs.is_open() )
       return false;
 
    fs << "{alberti_alphabets}\n";
 
    for( vector<string>::const_iterator it = sequence.begin(); it != sequence.end(); it++ )
       fs << *it << '\n';
 
    fs.close();
    return true;
}
 
/* засшифровать файл src_file_name, записав результат в dst_file_name,
   используя набор шифроалфавитов sequence */
bool encrypt( const string &src_file_name, const string &dst_file_name, const vector<string> &sequence )
{
    ifstream ifs( src_file_name );
    ofstream ofs( dst_file_name );
 
    if( !ifs.is_open() || !ofs.is_open() )
    {
        ifs.close();
        ofs.close();
 
        return false;
    }
 
    char ch;
    vector<string>::const_iterator alph_it = sequence.begin();
 
    while( !ifs.eof() )
    {
        ch = ifs.get();
 
        if( ch == EOF )
           break;
 
        ofs.put( ( (*alph_it).find( ch ) == string::npos ) ? ch : (*alph_it)[ ch - ' ' ] );
 
        alph_it++;
 
        if( alph_it == sequence.end() )
           alph_it = sequence.begin();
    }
 
    ifs.close();
    ofs.close();
 
    return true;
}
 
/* расшифровать файл src_file_name, записав результат в dst_file_name,
   используя набор шифроалфавитов sequence */
bool decrypt( const string &src_file_name, const string &dst_file_name, const vector<string> &sequence )
{
    ifstream ifs( src_file_name );
    ofstream ofs( dst_file_name );
 
    if( !ifs.is_open() || !ofs.is_open() )
    {
        ifs.close();
        ofs.close();
 
        return false;
    }
 
    char ch;
    size_t pos;
    vector<string>::const_iterator alph_it = sequence.begin();
 
    while( !ifs.eof() )
    {
        ch = ifs.get();
 
        if( ch == EOF )
           break;
 
        pos = (*alph_it).find( ch );
        ofs.put( pos == string::npos ? ch : pos + ' ' );
 
        alph_it++;
 
        if( alph_it == sequence.end() )
           alph_it = sequence.begin();
    }
 
    ifs.close();
    ofs.close();
 
    return true;
}
 
int main( )
{
    vector<string> alphabets; // шифроалфавиты
    string last_alphabet; // алфавит, который последний раз сгенерировала generate_alphabet
 
    string cmd; // введённая команда
 
    cout << "Alberti cypher utility v1.0\ntype help if you don't know what to do\n";
 
    // меню пользователя
    do
    {
        cout << "> ";
        cin >> cmd;
 
        if( cmd == "generate" )
        {
            last_alphabet = generate_alphabet();
            cout << last_alphabet << '\n';
        }
        else if( cmd == "push" )
        {
            if( !last_alphabet.length() )
               cout << "no alphabet in memory\n";
            else
            {
                alphabets.push_back( last_alphabet );
                cout << "alphabet sequence now contains " << alphabets.size() << " elements\n";
            }
        }
        else if( cmd == "print" )
        {
            for( vector<string>::iterator it = alphabets.begin();
                 it != alphabets.end(); it++ )
                     cout << *it << '\n';
 
            cout << "-- " << alphabets.size() << " alphabets\n";
        }
        else if( cmd == "erase" )
        {
            alphabets.clear();
            cout << "alphabet sequence is erased\n";
        }
        else if( cmd == "load" )
        {
            string fileName;
 
            cout << "current alphabet sequence will be appended with one that will be loaded from file\nfile name or \"#\" to abort> ";
            cin >> fileName;
 
            if( fileName == "#" )
               cout << "aborted.\n";
            else if( !load_alphabets( fileName, alphabets ) )
               cout << "failed.\n";
            else
               cout << "alphabet sequence now contains " << alphabets.size() << " elements\n";
        }
        else if( cmd == "save" )
        {
            string fileName;
 
            cout << "file name or \"#\" to abort> ";
            cin >> fileName;
 
            if( fileName == "#" )
               cout << "aborted.\n";
            else if( !save_alphabets( fileName, alphabets ) )
               cout << "failed.\n";
            else
               cout << "ok.\n";
        }
        else if( cmd == "encrypt" )
        {
            if( !alphabets.size() )
            {
                cout << "current alphabet sequence is empty\n";
                continue;
            }
 
            string srcFileName;
            string dstFileName;
 
            cout << "source file name or \"#\" to abort> ";
            cin >> srcFileName;
 
            if( srcFileName == "#" )
            {
               cout << "aborted.\n";
               continue;
            }
 
            cout << "destination file name or \"#\" to abort> ";
            cin >> dstFileName;
 
            if( dstFileName == "#" )
            {
               cout << "aborted.\n";
               continue;
            }
            else if( srcFileName == dstFileName )
               cout << "file names should not match\n";
            else if( !encrypt( srcFileName, dstFileName, alphabets ) )
               cout << "failed.\n";
            else
               cout << "ok.\n";
        }
        else if( cmd == "decrypt" )
        {
            if( !alphabets.size() )
            {
                cout << "current alphabet sequence is empty\n";
                continue;
            }
 
            string srcFileName;
            string dstFileName;
 
            cout << "source file name or \"#\" to abort> ";
            cin >> srcFileName;
 
            if( srcFileName == "#" )
            {
               cout << "aborted.\n";
               continue;
            }
 
            cout << "destination file name or \"#\" to abort> ";
            cin >> dstFileName;
 
            if( dstFileName == "#" )
            {
               cout << "aborted.\n";
               continue;
            }
            else if( srcFileName == dstFileName )
               cout << "file names should not match\n";
            else if( !decrypt( srcFileName, dstFileName, alphabets ) )
               cout << "failed.\n";
            else
               cout << "ok.\n";
        }
        else if( cmd == "help" )
        {
            cout << "generate  - generates a random alphabet\n"
                    "push      - pushes the last generated alphabet into\n"
                    "            the alphabet sequence\n"
                    "print     - prints current alphabet sequence\n"
                    "erase     - erases current alphabet sequence\n"
                    "load      - loads current alphabet sequence from a file\n"
                    "            appending it's contents to the current sequence\n"
                    "save      - saves current alphabet sequence to a file\n"
                    "encrypt   - encrypts a file with current alphabet sequence\n"
                    "decrypt   - decrypts a file with current alphabet sequence\n"
                    "help      - displays this message\n"
                    "quit      - terminates the program\n";
        }
 
    }
    while( cmd != "quit" );
 
    cout << "Goodbye.\n";
 
    return 0;
}
Генерирует шифроалфавиты, собирает наборы шифроалфавитов, сохраняет и загружает наборы из файлов, шифрует файлы наборами шифроалфавитов.
 
Текущее время: 08:02. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru