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

Гаммирование - C++

Восстановить пароль Регистрация
Другие темы раздела
C++ Помогите исправить ошибку. Вывести на печать фамилию и возраст работников 3 отдела. http://www.cyberforum.ru/cpp-beginners/thread987678.html
Добрый день, помогите исправить ошибку) Вывести на печать фамилию и возраст работников 3 отдела // обработка.cpp: определяет точку входа для консольного приложения. // #include "stdafx.h" #include "string" #include "iostream" #include "fstream" using namespace std;
C++ Дан файл целых чисел. Удалить из него все элементы с четными номерами. Помогите. Дан файл целых чисел. Удалить из него все элементы с четными номерами. Помогите сделать хотя бы для вида пусть код даже не работает если. http://www.cyberforum.ru/cpp-beginners/thread987662.html
Преобразования типов C++
Имеется такое выражение t=(i*j)*((e^(x))) ,где t-double x,i,j-int e-float Когда подставляю значения и считаю выдает ошибку, error C2296: ^:недопустимо, левый операнд имеет тип "float" Вроде как должно преобразовываться так double=int*float, почему такая ошибка? Спасибо.
C++ Метод Рунге-Кутта
Помогите написать метод Рунге Кутта для решение систем диф. уравнений из 4 уравнений. dx/dt=Px=f1(t,x,y,Px,Py) dy/dt=Py=f2(t,x,y,Px,Py) dPx/dt=-(w^2)*x-2axy=f3(t,x,y,Px,Py) dPy/dt=-(w^2)*y-ax^2+by^2=f4(t,x,y,Px,Py) void Rugge_Kutte2(double h,double &Xo,double &Yo,double &PXo,double &PYo,double a,double b) { //вместо t везде нули, так как в f1,f2,f3,f4 оно не на что не влияет ...
C++ Как работает компилятор при создании объекта http://www.cyberforum.ru/cpp-beginners/thread987639.html
Таки думал разобрался как работает конструктор копирования, а выходит, что нет. Вопрост состоит в следующем. Имеем код представляющий собой класс для хранения указателей на строки которые хранятся в другом классе(суть в том что бы не хранить в памяти несколько копия строк если они идентичны): #include<iostream> using namespace std; ////////////////////////////////////////////////////////...
C++ Вывод таблицы значений фенкций Написать программу,которая выводит таблицу значений финкции >^(x-2)+(x+1). Диапазон изменения аргумента вводится пользователем так же как и шаг приглашение аргумента. подробнее

Показать сообщение отдельно
Джем
1 / 1 / 0
Регистрация: 04.03.2013
Сообщений: 40
25.10.2013, 14:24     Гаммирование
Разработать программу на С++ для реализации алгоритма шифрования и расшифрования данных, используя метод гаммирования и поразрядного циклического сдвига. Алгоритм: для блока данных заданного размера берется такого же размера фрагмент гаммы и выполняется операция поразрядного исключающего «ИЛИ», далее, выполняется операция поразрядного циклического сдвига на заданное число бит влево или вправо с полученным новым блоком. Расшифрование выполняется в обратном порядке, вначале циклический сдвиг в противоположную сторону, а затем операция поразрядного исключающего «ИЛИ» с блоками той же самой гаммы.
Для получения гаммы можно использовать стандартный генератор псевдослучайный чисел (функцию rand, функция rand() генерирует воспроизводимую последовательность псевдослучайных чисел, при каждом обращении к функции возвращается целое в интервале между нулем и значением RAND_MAX, которое в любой реализации должно быть не меньше числа 32767, обратить внимание, при величине обрабатываемого блока данных 4 байта, возможно, для заполнения блока гаммы использовать два вызова функции), для начальной инициализации генератора использовать функцию srand (значение начальной инициализации является частью секретного ключа, другой частью ключа является размер поразрядного сдвига и его направление). Шифруемые данные хранить в программе в виде строки (можно сохранять в файле и читать из файла).

Мой вариант: сдвиг на 2 бита, размер обрабатываемого блока 1 байт.

Очень прошу помочь, не получается нормально сделать... Шифрует, а расшифровывать не хочет
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
#include <iostream>
#include "stdafx.h"
#include <locale.h>
#include <string.h>
#include<conio.h>
#include<stdio.h>
#include <stdlib.h>
 
const int MAX=1000; // MAX - Максимальное количество символов
// PrintLine - Функция печати строки длиной в 'b' символов
void PrintLine(char *line, int b)
{
    for (int i=0; i<b; i++)
        printf("%c", line[i]);
    printf("\n");
}
//Функция для шифрования данных
void shifrovanie(char *first, char *late,  int y, int n)
{
    srand(n);   // Инициализация секретного ключа 'n'
    unsigned short Gamma;   // Гамма
    int SizeLateBlock;  // Размер последнего блока
    unsigned short Block1, Block2;  // Блоки, которые будут использованы в качестве буфера обмена
    int x;  // x - Количество блоков памяти
    
    x=y/1; //  Количество блоков памяти по 1 байт
    
    if (x*1!=y)     // Проверка количества блоков по 1 байт
    {
        SizeLateBlock=1;    // Если есть лишний блок, то его размер - 1 байт
        x++;    // Увеличиваем кол-во итераций цикла (для обработки последнего блока размером 1 байт)
    }
    else SizeLateBlock=1;
    
    for (int i=1; i<=x; i++)
    {
        Gamma=rand();   // Генерируем гамму с помощью генератора псевдослучайных чисел
        unsigned short Mask=0x8000;  // Маска для сохранения одного старшего бита
        
        if (i!=x)   // Проверка, является ли обрабатываемый блок последним
        {
            memcpy(&Block1, first+(i-1), 1);    //  Копирование блока исходных данных размером 1 байт из исходной строки в буферный блок данных
            Block2=Block1^Gamma; // Наложение гаммы на буферный блок данных, используя операцию поразрядного исключающего "ИЛИ"
            Block1=Block2 & Mask; // Наложение маски, чтобы выделить отдельные биты и сохранить их в отдельном буферном блоке
            Block1>>=14; // Выполнениеоперации поразрядного сдвига на 14 бит вправо
            Block2<<=2; // Выполнение операции поразрядного сдвига на 2 бита влево
            Block2|=Block1; // Использование операции поразрядного "ИЛИ", получение поразрядно сдвинутого на 2 бита влево исходного блока с наложенной гаммой
            memcpy(late+(i-1), &Block2, 1); // Копирование результата из буфера в блок с зашифрованными данными
        }
        else  // Если блок последний
        {
            if (SizeLateBlock==1)
                Mask>>=4;   // Сдвиг маски, если размер последнего блока данных - 1 байт
            Block1=0; // Далее те же операции, но с учетом того, что идет обработка одного или двух байтов
            memcpy(&Block1, first+(i-1), SizeLateBlock);
            Block2=Block1^Gamma;
            Block1=Block2 & Mask;
            Block1>>=(14-4*(1-SizeLateBlock)); // Учитывание размера последнего блока
            Block2<<=2;
            Block2 = Block1;
            memcpy(late+(i-1), &Block2, SizeLateBlock);
        }
        
    }
}
//Функция для расшифровывания данных
 using namespace std;
void deshifrovanie(char *late, char *first, int y, int n)
{
    srand(n); // Инициализация секретного ключа
    unsigned short Gamma;   // Гамма
    int x; // x - Количество блоков памяти
    int SizeLateBlock; // Размер последнего блока
    unsigned short Block1, Block2;  // Блоки, которые будут использованы в качестве буфера обмена
    
    x=y/1; //  Количество блоков памяти по 1 байт
    
    if (x*1!=y) // Проверка количества блоков по 1 байт
    {
        SizeLateBlock=1; // Если есть лишний блок, то его размер - 1 байт
        x++; // Увеличивание кол-ва итераций цикла(для обработки последнего блока размером 1 байт)
    }
    else SizeLateBlock=1;
    
    for (int i=1; i<=x; i++)
    {
        Gamma=rand(); // Генерация гаммы с помощью генератора псевдослучайных чисел
        unsigned short Mask=0x0001; // Маска для сохранения двух младших битов
        if (i!=x) // Проверка, является ли обрабатываемый блок последним
        {
            memcpy(&Block1, late+(i-1), 1); // Копирование блока зашифрованных данных размером 1 байт из исходной строки в буферный блок данных
            Block2=Block1 & Mask; // Наложение маски, чтобы выделить отдельные биты и сохранить их в отдельном буферном блоке
            Block2<<=14; // Выполнение операции поразрядного сдвига на 14 бит влево
            Block1>>=2; // Выполнение операции поразрядного сдвига на 2 бита вправо
            Block1|=Block2; // Использование операции поразрядного "ИЛИ", получение поразрядно сдвинутого на 1 бит вправо исходного блока зашифрованных данных
            Block2=Block1^Gamma; // Наложение гаммы, используя операцию поразрядного исключающего "ИЛИ", и получаем блок исходных данных
            memcpy(first+(i-1), &Block2, 1); // Копирование результата из буфера в блок с расшифрованными данными
        }
        else
        {
            Block1=0; // Далее те же операции, что и при выполнении условия, с учетом того, что идет обработка одного или двух байтов
            memcpy(&Block1, late+(i-1), SizeLateBlock);
            Block2=Block1 & Mask;
            Block2<<=(14-4*(1-SizeLateBlock)); // Учитываем размер последнего блока
            Block1>>=2;
            Block1|=Block2;
            Block2=Block1^Gamma;
            memcpy(first+(i-1), &Block2, SizeLateBlock);
        }
        
    }
}
//Главная функция 
int main()
{
    setlocale(LC_ALL, "rus");
    int  Key;   // Key - Секретный ключ
    char Original[MAX], Encrypt[MAX], Decrypt[MAX]; // Original - Исходные, Encrypt - Зашифрованные, Decrypt - Расшифрованные
    int a;
    printf("Введите данные, которые вы хотите зашифровать: ");
    gets(Original); // Ввод исходных данных
    a=strlen(Original); // Длина строки
    printf("Введите ключ: ");
    scanf("%d", &Key); // Ввод секретного ключа
    shifrovanie(Original, Encrypt, a, Key); // Шифрование исходных данных
    printf("\nЗашифрованные данные: ");
    PrintLine(Encrypt, a); // Вывод зашифрованных данных на экран
    printf("\nВведите ключ: ");
    scanf("%d", &Key); // Ввод секретного ключа
    srand(Key);
    deshifrovanie(Encrypt, Decrypt, a, Key); // Расшифровывание зашифрованных данных
    printf("\nРасшифрованные данные: ");
    PrintLine(Decrypt,a);   //Вывод расшифрованных данных
    getch();
    return 0;
}
Заранее спасибо!
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
Текущее время: 11:40. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru