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

Шифр сдвига (Цезаря) - C++

Восстановить пароль Регистрация
 
Рейтинг: Рейтинг темы: голосов - 41, средняя оценка - 5.00
SLaFko_0
0 / 0 / 0
Регистрация: 27.02.2010
Сообщений: 35
05.05.2010, 17:47     Шифр сдвига (Цезаря) #1
скажите как сделать шифр в кольце 26(для латиницы), т.е. чтобы последняя буква в первую переходила
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
int main()
{
        setlocale(LC_CTYPE,"russian");
        int k;
        char buff[50];
        cout<<"Введите сообщение : ";
        cin>>buff;
        cout<<"Введите кол-во букв для сдвига : ";
        cin>>k;
        for(int i = 0;i < strlen(buff); i++)
        buff[i] += k;
        cout<<"Шифр : "<< buff<<endl;
        
        cout<<"Расшифровка : ";
        for(int i = 0;i < strlen(buff); i++)
        buff[i] -= k;
        
        cout<<buff<<endl;
        system("pause");
}
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
05.05.2010, 17:47     Шифр сдвига (Цезаря)
Посмотрите здесь:

Шифр Цезаря C++
C++ Шифр Цезаря
Шифр Цезаря полосками C++
C++ Шифр цезаря на кириллице
C++ Кириллица. Шифр Цезаря
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
SLaFko_0
0 / 0 / 0
Регистрация: 27.02.2010
Сообщений: 35
07.05.2010, 13:03  [ТС]     Шифр сдвига (Цезаря) #2
или хотя бы взлом частотным анализом мб кто знает
Liebe
...
 Аватар для Liebe
891 / 74 / 5
Регистрация: 21.02.2010
Сообщений: 2,196
Записей в блоге: 1
07.05.2010, 14:58     Шифр сдвига (Цезаря) #3
Цитата Сообщение от SLaFko_0 Посмотреть сообщение
скажите как сделать шифр в кольце 26(для латиницы), т.е. чтобы последняя буква в первую переходила
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
int main()
{
        setlocale(LC_CTYPE,"russian");
        int k;
        char buff[50];
        cout<<"Введите сообщение : ";
        cin>>buff;
        cout<<"Введите кол-во букв для сдвига : ";
        cin>>k;
        for(int i = 0;i < strlen(buff); i++)
        buff[i] += k;
        cout<<"Шифр : "<< buff<<endl;
        
        cout<<"Расшифровка : ";
        for(int i = 0;i < strlen(buff); i++)
        buff[i] -= k;
        
        cout<<buff<<endl;
        system("pause");
}
надо сложение и вычитание делать по модулю 26.
только сдается мне, что у тебя шифрование не совсем правильно реализовано.

Добавлено через 29 минут
п.с. хотя нет, все правильно, померещилось ))
Alip
53 / 32 / 3
Регистрация: 10.03.2010
Сообщений: 85
07.05.2010, 15:49     Шифр сдвига (Цезаря) #4
Вот. Чуток дополнив, получаем кольцевое шифрование. Не проверял, поэтому посмотри сам. Сделал только для маленьких латинских.
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
int main()
{
        setlocale(LC_CTYPE,"russian");
        int k;
        char buff[50];
        cout<<"Введите сообщение : ";
        cin>>buff;
        cout<<"Введите кол-во букв для сдвига : ";
        cin>>k;
    char final='z'-k+1;
 
        for(int i = 0;i < strlen(buff); i++)
        if (buff[i]<final)  buff[i] += k;
        else  buff[i]='a'+buff[i]-final;    
        cout<<"Шифр : "<< buff<<endl;
    
        char start='a'+k-1;
        cout<<"Расшифровка : ";
        for(int i = 0;i < strlen(buff); i++)
        if (buff[i]>start)  buff[i] -= k;
        else  buff[i]='z'-buff[i]+start;
                
        cout<<buff<<endl;
        system("pause");
}
SLaFko_0
0 / 0 / 0
Регистрация: 27.02.2010
Сообщений: 35
07.05.2010, 16:59  [ТС]     Шифр сдвига (Цезаря) #5
расшифровывает не в кольце 26 (
выводит другие элементы из таблицы символов

Добавлено через 21 минуту
с буквой "z" расшифровывает при любом сдвиге, а если взять "y" и далее, то уже не в кольце расшифровывает
Liebe
...
 Аватар для Liebe
891 / 74 / 5
Регистрация: 21.02.2010
Сообщений: 2,196
Записей в блоге: 1
07.05.2010, 18:31     Шифр сдвига (Цезаря) #6
Цитата Сообщение от SLaFko_0 Посмотреть сообщение
расшифровывает не в кольце 26 (
выводит другие элементы из таблицы символов

Добавлено через 21 минуту
с буквой "z" расшифровывает при любом сдвиге, а если взять "y" и далее, то уже не в кольце расшифровывает
попробуй поменять в 21 строке
C++
1
  else  buff[i]='z'+buff[i]-start;
Mr.X
Эксперт С++
 Аватар для Mr.X
2802 / 1578 / 247
Регистрация: 03.05.2010
Сообщений: 3,666
07.05.2010, 20:51     Шифр сдвига (Цезаря) #7
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
//шифр в кольце 26(для латиницы), т.е. чтобы последняя буква в первую переходила
#include <iostream>
#include <string>
#include <algorithm>
 
const size_t period = 26;
 
bool is_lat_alpha(int ch)
{
    return 'a' <= ch && ch <= 'z';
}
 
int code_symb(int ch, int sh)
{
    if(!is_lat_alpha(ch)) return ch;
    return (ch - 'a' + sh) % period + 'a';
}
 
std::string code(std::string txt, int sh)
{    
    for(size_t i = 0; i < txt.length(); ++i)
    {
        txt[i] = code_symb(txt[i], sh);
    }
    return txt;
}
 
int decode_symb(int ch, int sh)
{
    if(!is_lat_alpha(ch)) return ch;
    int res = ch - 'a' - sh;
    while(res < 0) res += period;
    return res % period + 'a';
}
 
std::string decode(std::string txt, int sh)
{    
    for(size_t i = 0; i < txt.length(); ++i)
    {
        txt[i] = decode_symb(txt[i], sh);
    }
    return txt;
}
 
int main()
{
    std::string text;
    std::string coded_text;
    std::string decoded_code;
    int shift;
    for(;;)
    {    
        text.clear();
        std::cout << "Input latin lower text: "
                  << std::endl;        
        std::cin >> text;
        std::cout << "Input shift > 0: ";
        std::cin >> shift;
        std::cout << "Coded text: "
                  << (coded_text = code(text, shift))
                  << std::endl;
        std::cout << "Decoded code: "
                  << std::endl
                  << (decoded_code = decode(coded_text, shift))
                  << std::endl
                  << std::endl
                  << std::endl;
    }
    return 0;
}
SLaFko_0
0 / 0 / 0
Регистрация: 27.02.2010
Сообщений: 35
11.05.2010, 19:22  [ТС]     Шифр сдвига (Цезаря) #8
может кто-нибудь помочь, чтобы дешифрование частотным анализом было?

Добавлено через 7 минут
для английского языка
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
06.06.2010, 21:36     Шифр сдвига (Цезаря)
Еще ссылки по теме:

Шифр Цезаря (пароль) C++
Шифр Цезаря C++
Шифр Цезаря C++

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

Или воспользуйтесь поиском по форуму:
Алиса1000000
0 / 0 / 0
Регистрация: 06.06.2010
Сообщений: 7
06.06.2010, 21:36     Шифр сдвига (Цезаря) #9
Чуваки, не мучайтесь: Шифр Цезаря
Yandex
Объявления
06.06.2010, 21:36     Шифр сдвига (Цезаря)
Ответ Создать тему
Опции темы

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