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

Код шифровки методом прямой замены - C++

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Преобразование типов. Не конструктор не видит класс http://www.cyberforum.ru/cpp-beginners/thread888527.html
Здравствуйте. В коде ниже, я хотел реализовать конвертер длин. Я создал 2 класса и при помощи 2 конструкторов хотел решить проблему преобразования типов. Если оставить один конструктор, то все работает, а с двумя выводит ошибку. Я начинающий и не могу додуматься как её можно исправить. Помогите решить эту проблему. #include <iostream> #include<locale.h> using namespace std; int vibor; void...
C++ Строквой литерал в двоичном представлении Добрый день. В учебнике есть задание: составить пользовательский тип который может вместить значение факториала числа 1000 с абсолютной точностью. На данном этапе мне необходимо считать со строки значение и перевести его в бинарное представление (т.е. инициализировать мой тип данных). Как это сделать? Перевести в целочисленный аргумент с последующим делением на 2 и взятием остатка, как мне... http://www.cyberforum.ru/cpp-beginners/thread888526.html
C++ Ошибка при работе с dll - невозможно преобразовать параметр
пишу прогу, функции передаются с dll, выдает ошибку в строке HINSTANCE mydll = LoadLibrary ("my_dll.dll"); error C2664: LoadLibraryW: невозможно преобразовать параметр 1 из "const char " в "LPCWSTR" почему ругается?( в 1 раз с dll работаю(
Ошибка в функции C++
#include <iostream> #include <conio.h> #include <Windows.h> #include <iomanip> using namespace std; char bufUkr; char *Ukr(const char* text) {
C++ Сделать что-бы строка бралась с файла (определить отношение количества гласных букв в предложении к согласным) http://www.cyberforum.ru/cpp-beginners/thread888498.html
Задание: Определить отношение количества гласных букв в предложении к согласным. код:#include <iostream> #include <conio.h> #include <string> #include <cctype> using namespace std; int main() { string a;
C++ Зеркально поменять местами разряды младшего байта четных чисел, затем определить максимальное число в массиве и его индекс Помогите! Очень срочно! Нужно написать программу: 2. Зеркально поменять местами разряды младшего байта четных чисел, затем определить максимальное число в массиве и его индекс Желательно с пояснениями!!))) Заранее Спасибо) подробнее

Показать сообщение отдельно
Alex ccp
0 / 0 / 0
Регистрация: 13.05.2013
Сообщений: 12

Код шифровки методом прямой замены - C++

02.06.2013, 20:53. Просмотров 246. Ответов 0
Метки (Все метки)

Код писал не я , программа шифрует текст методом прямой замены.
Не могу понять ,где та часть кода где собственно реализуется перестановка символов .

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
#iinclude<iostream.h>
#include<conio.h>
#include<fstream.h>
#include<string.h>
#include<math.h>
#include"rus.h"
#pragma hdrstop
//---------------------------------------------------------------------------
#pragma argsused
void main()
{
  char* kluch;  //резервируем адрес для ключевого выражения
  ifstream inp("Input.txt");
  ofstream out("Output.txt");
  if(!inp)
    {
       cout<<Rus("ОТСУТСТВУЕТ ФАЙЛ Input.txt");
       getch();
       exit(1);
     }  
  cout<<Rus("ВВЕДИТЕ КЛЮЧ (БЕЗ ПРОБЕЛОВ)");
  cin>>kluch;
  int n=strlen(kluch);   //длина ключа
  int b,j,i=0;
  for(int k=0;k<n;k++)
   {         //преобразование символов ключа в прописные
     b=kluch[k];
     if(b<=-33&&b>=-64)b+=32;   //A->а,Б->б,...(русский алфавит)
     if(b==-81||b==-88||b==-86)b+=16; //Ї->ї,Є->є,Ё->ё
     if(b<=90&&b>=65)b+=32;    //A->a, B->b,...(английский )
     kluch[k]=b;
   }
  char temp,buffer=NULL;//buffer-считываемый символ, temp- преобразов. символ
 
  while(!inp.eof()) //пока не достигнут конец файла
    {
       inp.read((char*)&buffer,sizeof(buffer));//считываем очередной символ
       if(buffer==NULL)break;// если файл пустой
       b=buffer;
            //преобразование символов исходного текста в заглавные
       if(b>=-32&&b<=-1)b-=32;  //а->А,б->Б,...(русский алфавит)
       if(b==-65||b==-72||b==-70)b-=16; //ї->Ї,є->Є,ё->Ё
       if(b>=97&&b<=122)b-=32;  //a->A, b->B,...(английский )
       buffer=b;
 
       j=fmod(i,n); // переменная j циклически изменяется от 0 до n-1
       temp=buffer^kluch[j];// применяем операцию "исключающее ИЛИ"
       out.put(temp);  //записываем кодированный символ
       i++;   //переходим к следующему символу ключевого слова
       buffer=NULL; 
    }
 
  inp.close();
  out.close();
  cout<<Rus("ЗАШИФРОВАННЫЙ ТЕКСТ НАХОДИТСЯ В ФАЙЛЕ Output.txt");
  getch();
}
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
Текущее время: 04:13. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru