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

Дешифратор по имеющемуся словарю - C++

Восстановить пароль Регистрация
 
sly4ainaya
2 / 2 / 0
Регистрация: 11.03.2011
Сообщений: 49
17.03.2011, 21:25     Дешифратор по имеющемуся словарю #1
Дешифратор почему-то не работает.. на входе подается зашифрованный текст, имея "эталоны" словоформ нужно расшифровать этот текст. Ко всем символам зашифрованного текста прибавляются ключи от 1до 255 и потом получившееся при сложении с ключом сравнивается с элементами в словаре..

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
#include <iostream> 
#include <list>
#include <vector>
#include <fstream> 
#include <Cstring>
#include <cctype>
#include <algorithm>
#include <iterator>
#include <conio.h>
#include <string>
#include <iostream>
using std::string;
using namespace std;
void main()
{
    char new_file[256], s; //путь к файлу, который надо расшифровать
    char symbol,ssymbol; //
    string symbol_dictionary, symbol_decoder, coded;
    int key;
    vector<string> the_list_input, the_list_dictionary; //вектор строк в который будут записаны элементы зашифрованного файла и словаря
 
    cout<<"Write way to coded file"<<endl; //просим ввести путь к зашифрованному файлу
    cin>>new_file; //вводим путь к зашифрованному файлу
    ifstream in (new_file, ios::binary); //связываем с этим файлом входной поток
    ifstream dictionary ("dictionary.txt", ios::binary); // входной поток для получения данных из словаря
    ofstream out ("decoded.txt", ios::binary); //расшифрованный файл
 
    FILE *dict = fopen("dictionary.txt", "rb"); //открываем словарь
    fseek(dict, 0, SEEK_END);           //устанавливаем позицию от конца до нуля, находим размер
    long long size2 = ftell(dict); //сообщаем размер словаря
    long long  size_dictionary= size2; //сохраняем размер словаря 
    fseek(dict, 0, SEEK_SET);      //возвращаемся в начало
 
    while(size2!=0) //пока не конец
    {
        dictionary>>symbol_dictionary; //считываем слово из словаря
        the_list_dictionary.push_back(symbol_dictionary); //добавляем слово в список
        size2--;        
    }
 
    FILE *fp = fopen(new_file, "rb"); //открываем исходный файл
    fseek(fp, 0, SEEK_END);           //устанавливаем позицию от конца до нуля, находим размер
    long long size = ftell(fp);  //записываем размер исходного файла
    fseek(fp, 0, SEEK_SET);      //возвращаемся в начало
        
    getline(in, symbol_decoder); 
        
    int n=0, right_word=0, word=0; //счетчики слов в исходном файл и слов совпавших со словами в словаре
 
    for (int i=0; i<=255; i++) //цикл для прибавления к символаm всех ключей
    {
        for (int j=0; j<size-1; j++)//как бы расшифрованное         
            if(symbol_decoder[j]=='\n')
                    break;
            else
                    symbol_decoder[j]=(symbol_decoder[j]+1)%256;
        symbol_dictionary.clear();
        //нужно как бы расшифрованную строку записать в вектор
        for(int j=0; j<size-1; j++) //записываем вектор элементами которого являются слова
            if(symbol_decoder[j]==' ')
            {
                the_list_input.push_back(symbol_dictionary);
                symbol_dictionary.clear();
                word++;
            }
            else
                symbol_dictionary.append(1,symbol_decoder[j]);//записываем слово посимвольно
        if(word==0)//если слов 0
            continue;
        for(int k=1; k<20; k++)//если слов не ноль, сравниваем слова с теми, которые есть в словаре, считаем число совпавших и запоминаем ключ
        {
            for (int j=1; j<size_dictionary-2; j++)         
            {
                if(the_list_input[k].compare(the_list_dictionary[j])>0)
                    right_word++;
                if (right_word>5)
                {
                    key=i;
                    break;
                }
            }
            if (right_word>5)
            {
                key=i;
                break;
            }
        }
    }
    out<<key;
}
Добавлено через 1 час 3 минуты
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
17.03.2011, 21:25     Дешифратор по имеющемуся словарю
Посмотрите здесь:

дешифратор цезаря C++
Дешифратор кода картинки.. C++
Дешифратор C++
C++ Шифратор и дешифратор
Метод, возвращающий данные по имеющемуся ключу массива MAP C++
C++ Выделение в исходном коде программы ключевых слов языка и операторов языка по словарю
Написать шифратор\дешифратор на С++ C++
C++ Поиск по словарю

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

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
Ответ Создать тему
Опции темы

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