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

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

Восстановить пароль Регистрация
Другие темы раздела
C++ вроде все просто http://www.cyberforum.ru/cpp-beginners/thread259280.html
#include "stdafx.h" #include <iostream> #include <ctime> using namespace std; int main() { int mas, a; srand (time(NULL)); for(int i = 0; i < 10; i++)
C++ Можно ли сортировки некоторые сделать устойчивыми? Тут такое задание:рассмотреть 4алгоритма : сортировка вставками,сортировка слиянием,сортировка с помощью кучи,быстрая сортировка.Можно ли сделать их устойчивыми?если да,то пример в с/с++,если нет то почему? http://www.cyberforum.ru/cpp-beginners/thread259226.html
C++ Точность и т.д.
1)Дано два целых числа a і b. Виведите гипотенузу с катетами a и b с точностью 6 знаков. Вх одные данные Два целих числа a и b (0 < a, b < 1000). Тут выводиться всего 6 знаков, а нужно 6 знаков после точки, что делать? #include <iostream> #include <math.h> #include <iomanip> using namespace std;
Запутанная матрица C++
Как решить следующую задачу? N(10, 10) Из положительных элементов матрицы N сформировать матрицу M (10, KMAX), располагая их в строках матрицы подряд, где KMAX-максимальное число положительных элементов строки матрицы N. Записать нули на место отсутствующих элементов. Отпечатать обе матрицы в общепринятом виде.
C++ Строки и файлы http://www.cyberforum.ru/cpp-beginners/thread259158.html
Всем доброго времени суток! Пролежал в больнице половину семестра и сейчас не понимаю как решить задачи(самый простые даже по моему). Я не прошу решить их за меня. Не могли бы вы объяснить принцип их решения? 1. Дан текстовый файл, фразы в котором отделены друг от друга точками, а слова - пробелами и знаками препинания. Оставить в этом файле только те фразы, в которых имееться числовая...
C++ И снова матрицы В матрице А(N,M) найти Номер строки, в которой сумма элементов наибольшая Переставить местами строки содержащие первый максимальный элемент и последний минимальный подробнее

Показать сообщение отдельно
sly4ainaya
2 / 2 / 0
Регистрация: 11.03.2011
Сообщений: 49
17.03.2011, 21:25     Дешифратор по имеющемуся словарю
Дешифратор почему-то не работает.. на входе подается зашифрованный текст, имея "эталоны" словоформ нужно расшифровать этот текст. Ко всем символам зашифрованного текста прибавляются ключи от 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 минуты
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
Текущее время: 21:16. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru