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

Шифровка и расшифровка текста - C++

Восстановить пароль Регистрация
Другие темы раздела
C++ Реализовать операции с набором из объектов, состоящих из источник света в формате l- яркость , d-рассеивание , i-интенсивность http://www.cyberforum.ru/cpp-beginners/thread898266.html
объект: источник света в формате l- яркость , d-рассеивание , i-интенсивность. Из объектов строится набор конкретных значений. размер набора может изменяться динамически. реализовать операции с набором: динамическое изменение размера , добавление элементов , заполнение набора случайными значениями , получение элемента из набора, изменение элемента в наборе, сортировка набора.
C++ Программа должна распечатывать прописью значение суммы в долларах,если введена сумма в рублях,или... Суммы денег могут вводиться в рублях и долларах.Программа должна распечатывать прописью значение суммы в долларах,если введена сумма в рублях,или значение суммы в рублях,если введена сумма в долларах. http://www.cyberforum.ru/cpp-beginners/thread898261.html
C++ Как подключить библиотеку (*.lib)
Нашел библиотеку для загрузки изображений: http://www.sources.ru/cpp/cpp_cximage.shtml Не пойму как в свой проект подключить. У меня VS2010, в ней эта либа не собирается. Пришлось на виртуалке в VC6.0 откомпилить. Появился lib файл, его я перемещаю в папку своего проекта вместе с xImage.h, Оба подключаю: #pragma comment (lib, "cximage.lib") #include "xImage.h" И вылазиет 62 ошибки. Что не...
C++ Согласно варианту выбрать функцию y = f (x) для локализации корня уравнения f (x) = 0
Доброго времени суток, очень нужна ваша помощь в решении данной проблемы, буду бесконечно благодарен. Согласно варианту выбрать функцию y = f (x) для локализации корня уравнения f (x) = 0 И составить блок схем к программе.
C++ Где здесь ошибка http://www.cyberforum.ru/cpp-beginners/thread898234.html
под "а" #include <iostream> #include <math.h> #include <time.h> using namespace std; int main() { setlocale(0, "rus"); char m; int n;
C++ Есть алгоритм поиска простого цикла(ссылка прилагается). Но как найти все простые циклы в графе? Вот сам алгоритм поиска цикла в графе http://e-maxx.ru/algo/finding_cycle Как найти все простые циклы в графе? подробнее

Показать сообщение отдельно
ШурикМартыненко
4 / 4 / 1
Регистрация: 27.03.2013
Сообщений: 110
11.06.2013, 22:12     Шифровка и расшифровка текста
Зравствуйте! нижепредставленный код шифрует данные списком без проблем. Обратно не расшифровывает. Вернее, создаёт файл, но не то в нём записано. Собственно, сам код:
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
// Ваирант 6.cpp : Defines the entry point for the console application.
//
 
#include "stdafx.h"
#include <fstream>
#include <iostream>
using namespace std;
 
// Элемент списка (двунаправленного)
 
class TItem {
     public:
            TItem();
            char letter;         // Символ
            int code;            // Шифр этого символа
            TItem* next;
            TItem* prev;
};
 
// Собственно список
 
class TList {
    private:
        TItem* first;
        TItem* last;
    public:
        TList();
        void AddItem(char letter, int code);
       void Print();                    // Печать списка
        int GetCode(char letter);
};
char Symbols[]={'A','B','C','D','E','F','G','H','I','J','K','L','M','N','O','P','Q','R','S','T','U','V','W','X','Y','Z','a','b','c','d','e','f','g','h','i','j','k','l','m','n','o','p','q','r','s','t','u','v','w','x','y','z','0','1','2','3','4','5','6','7','8','9'};
 
int main() {
    setlocale(LC_ALL, "Russian");
 int choice;
 cout<<"Вы желаете:\n1. Зашифровать данные\n2. Расшифровать данные\n";
 cin>>choice;
 if (choice==1)
 {
// Создаём список -- добавляем символы и их шифры
    TList cypher;
 
    int i=1, j;
    for(j='A'; j<='Z'; j++, i++) 
        cypher.AddItem( (char)j, i );
    for(j='a'; j<='z'; j++, i++)
        cypher.AddItem( (char)j, i );
    for(j='0'; j<='9'; j++, i++)
        cypher.AddItem( (char)j, i );
 
// В том случае, если исходный файл, кот. требуется зашифровать, не существует, создаём файл для теста.
    {
        ifstream iftemp("source.txt");
        if(!iftemp) {
            ofstream oftemp("source.txt");
            oftemp << "Test Encrypting!\nRedhat goes to granny.";
            oftemp.close();
        }
        else
            iftemp.close();
    }
 
// Подключаем исходный и результирующий файлы.
        ifstream fin("source.txt");
    ofstream fout("encrypted.txt");
    char temp;
 
// Для шифр каждого символа в списке-шифре и записываем найденный шифр в результирующий файл
    while( fin ) {
        temp = (char)fin.get();          // Прочитали следующий символ из файла
        if(temp == EOF)  break;          // Если этот символ -- EOF, заканчиваем цикл
        if( !cypher.GetCode(temp) )
            fout << temp;            // Нашли шифр -- записали в файл-результат
        else
            fout << cypher.GetCode(temp) << '.';      // Не нашли шифр -- записали в файл-результат исходный символ
    }
 }
 else if (choice==2)
 {
    {
        ifstream iftemp("source.txt");
        if(!iftemp) {
            ofstream oftemp("source.txt");
            oftemp << "1.2.3.";
            oftemp.close();
        }
        else
            iftemp.close();
    }
 
// Подключаем исходный и результирующий файлы.
        ifstream fin("source.txt");
    ofstream fout("encrypted.txt");
    int temp;
// Для каждого символа в списке-шифре и записываем найденный шифр в результирующий файл
    while( fin ) {
        temp = (int)fin.get();          // Прочитали следующий символ из файла
        if(temp == EOF)  break;          // Если этот символ -- EOF, заканчиваем цикл
        else
        {
            for (int i=1;i<=62;i++){
                if (temp==i)
                    fout<<Symbols[i-1];}
        }
    }
 }
return 0;
}
 
// - - - - - - - - - - - -
 
 
 
 
// Конструкторы и методы
 
TItem::TItem() {
    letter = '\0';
    code = 0;
    next = NULL;
    prev = NULL;
}
 
TList::TList() {
    first = NULL;
    last = NULL;
}
 
// Метод. Добавляет новый элемент в список
 
void TList::AddItem(char letter, int code) {
    TItem* temp;
    temp = new TItem();
    temp->code = code;
    temp->letter = letter;
    if(!first) {
        first = temp;
    } else {
        last->next = temp;
        temp->prev = last;
    }
    last = temp;
}
// Метод. Поиск элемента списка по его содержимому.
 
int TList::GetCode(char letter) {
    TItem* temp;
    temp = first;
    while(temp) {
        if(temp->letter == letter) return temp->code;
        temp = temp->next;
    }
    return 0;
}
Добавлено через 11 часов 29 минут
Пожалуйста...((
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
Текущее время: 05:58. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru