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

Зашифровать строку Char, заменив каждый символ на его ASCII код - C++

Восстановить пароль Регистрация
Другие темы раздела
C++ Ошибка при компиляции http://www.cyberforum.ru/cpp-beginners/thread1075977.html
#include"stdafx.h" #include<iostream> #include<iomanip> #include<cmath> #include<time.h> int main() { float mas; srand(time(NULL));
C++ Посчитать сумму четных чисел Что бы подсчитывал сумму четных чисел. int main() { int a,n,x,z int x=0; cout <<"vvedite n="; cin>>n: kol=0; for (int k=0;k<n;k+1) { cout <<vvedite a="; http://www.cyberforum.ru/cpp-beginners/thread1075975.html
C++ Дан двумерный массив 3х3. Получить одномерный массив из из отрицательных элементов матрицы.
Пожалуйста, помогите решить простым методом задачку, просто не могу понять смысл ее выполнения. Дан двумерный массив 3х3.Получить одномерный массив из из отрицательных элементов матрицы. Заранее спасибо!
Найти сумму ряда с точностью E C++
Найти сумму ряда с точностью E , общий член которого равен a(n)=(10^n)/(n!) Точность считается достигнутой, если следующий член последовательности меньше заданного E .
C++ Найти элемент главной диагонали, имеющий максимальное значение http://www.cyberforum.ru/cpp-beginners/thread1075962.html
помогите пожалуйста с задачей. {a}_{i,j}=\begin{cases} i^2+{(i-j^b)}^{0.5}, if \text{ } i>3 & \text{ } \\ (b-0.375)*(b-i/j+5)/(1+(i+j)), if \text{ } i<=3 & \text{ } \end{cases} числовое значение b задается по вводу. найти элемент главной диагонали, имеющий максимальное значение. Напечатать элементы и номер соответствующей ему строки. попробовал сам, но такая абракадабра...
C++ Методы шифрования MD2, MD4 Нужно написать курсач по этим методам шифрования... Перерыл кучу универских методичек, о них сказано буквально 2 слова:"они - существуют". Пришёл к преподу, тот сказал что бы я искал "хэш-функцию". Буду благодарен хотя бы за пример кода по зашифровке текста этим методом... подробнее

Показать сообщение отдельно
stal_in
1 / 1 / 0
Регистрация: 22.03.2011
Сообщений: 52
19.01.2014, 23:06     Зашифровать строку Char, заменив каждый символ на его ASCII код
Собственное весь вопрос в заголовке темы.

Вся задача.
Кликните здесь для просмотра всего текста
Зашифровать строку Char, заменив каждый символ на его ASCII код


Весь код.
Кликните здесь для просмотра всего текста

Текущие функции кодирование декодирования не устраивают, лишние массивы и т.п. неочень. Функцию кодирования, пытался переработать, но не получается, как я понимаю из-за того, что я использую char, а не *char.
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
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
#include <cstring>
#include <stdio.h> 
#include <conio.h> 
#include <iostream>
#include <stdlib.h>
#include <string.h>
#include <math.h>
#include <cstdlib>
#include <algorithm>
 
using namespace std;
 
class simbStroka{
      public:
             char s[100];
             
             void vvod (){
                  cout<<"Bâåäèòå ñòðîêó äëÿ Г*Г*Г·Г*Г«Г* Г°Г*áîòû (ñòðîêó ââîäèòü Г«Г*ГІГЁГ*ñêèìè ГЎГіГЄГўГ*ìè):\n";
                  gets(s);
                  }
             void vivod (){
                  cout<<s;
                  }
             
             virtual void F1 ()=0;
             virtual void F2 ()=0;
             };
      class Perestanovka: public simbStroka{
            public:
             void F1 ()
             {
 
                    int i,j;
                    int x=0, n=0;
                    char m;
                    char s2[100]="";
                    strcpy(s2,s);
                    strcat(s2," ");            
                    for (i=0; i<strlen(s)+1; i++)
                                {   
                                    if ( s2[i]!=' ')
                                    {
                                    x++; //Г±Г·ГҐГІГ·ГЁГЄ ГЎГіГЄГў Гў ñëîâå
                                    //cout<<"x="<<x<<"n="<<n;
                                    } else {
                                         for (j=0; j<x/2; j++)
                                             {
                                              m=s2[j+n];
                                              s2[j+n]=s2[x-1+n];
                                              s2[x-1+n]=m;
                                              x--; 
                                             }
                                         x=0; //îáГ*óëÿåì Г±Г·ГҐГІГ·ГЁГЄ ГЎГіГЄГў Гў ñëîâå
                                         n=i+1; //ïîçèöèÿ Г*Г*Г·Г*Г«Г* ñëîâГ*
                                           }
                                 }
                 cout<<s2<<endl;
             }
                  
             void F2 (){
                  int i, k;
                  char s2[100]="";
                  char w[100]="";
                  strcat(s," "); //äîáГ*âëÿåì ГЄ ñòðîêå ïðîáåë
                  k = strlen(s)-1;      //èäåì Г± ГЄГ®Г*Г¶Г*
                  for (int i=strlen(s)-1;i>=0;i--)
                  {
                      if (s[i]==' ' || i==0) //Г*Г*ГІГЄГ*óëèñü Г*Г* ïðîáåë èëè Г*Г*Г·Г*ëî ñòðîêè
                            {
                        if (s[i]==' ') //Г*Г*ГІГЄГ*óëèñü Г*Г* ïðîáåë
                            {
                                copy(s + (i+1), s + (k+1), w); //âûáèðГ*ГҐГ¬ ñëîâî
                                strcat(s2,w);
                                char w[100]="";
 
                                k=i; //èäåì Г¤Г*ëüøå.
                            }else{
                                copy(s + i, s + k+1, w);
                                strcat( s2,w);
                                char w[100]="";
                            }
                            }
                    }
                    cout<<s2<<endl;
            }
    };
      class Kodirovanie: public Perestanovka{
            public:
             
                   void F1(char *string){
                   int i, j;
                   
                          for(i=0; i<strlen(string); i++)
                             {
                                   int number = string[i];
                                   sprintf(string[i], "%d", number);
                             }
                 }
                 
                 
             void F2(char *string){
                 int i, j;
                 int mas1[27] = { 00, 01, 02, 03, 04 ,05, 06, 07, (5+3), (5+4), 10, 11, 12, 13, 14 ,15, 16, 17, 18, 19 , 20, 21, 22, 23, 24, 25, 26};
                 char mas2[27] = { 'a', 'b', 'c', 'd', 'e', 'f', 'g', 'h', 'i', 'g', 'k', 'l', 'm', 'n', 'o', 'p', 'q', 'r', 's', 't', 'u', 'v', 'w', 'x', 'y', 'z', ' '};
                 
                 for(i=0; i<strlen(string); i++)
                 {
                          for(j=0; j<27; j++)
                          {
                                   if (mass[i] == mas1[j])
                                   {
                                            cout<<mas2[j];
                                            }
                                   }
                          }
                 }
             };
main(){
       setlocale(LC_ALL, "");
       
       int q;
       Perestanovka y;
       Kodirovanie p;
       
       for (q=0; q<100; q++)
       p.mass[q] = 0;
       
       y.vvod();
       cout<<"\n";
       cout<<"Âû ââåëè: ";
       y.vivod();
       cout<<"\n";
int eF=1;
while (eF!=0)
    {
       cout<<"Âûáåðèòå äåéñòâèå Г±Г® ñòðîêîé\n";
       cout<<"1 - ïåðåâåðГ*ГіГІГј ГўГ±ГҐ ñëîâГ* Гў ñòðîêå\n";
       cout<<"2 - ïåðåñòГ*ГўГЁГІГј ГўГ±ГҐ ñëîâГ* Гў îáðГ*ГІГ*îì ïîðÿäêå\n";
       cout<<"3 - Г§Г*êîäèðîâГ*ГІГј ñòðîêó\n";
       cout<<"4 - Г°Г*ñêîäèðîâГ*ГІГј ñòðîêó\n";
 
       cin>>q;
       
       switch(q)
       {
                case 1:
                     cout<<"\n";
                     y.F1();
                     cout<<"\n";
                     cout<<"\n";
                     break;
                case 2:
                     cout<<"\n";
                     y.F2();
                     cout<<"\n";
                     cout<<"\n";
                     break;
                case 3:
                     cout<<"\n";
                     p.F1(y.s);
                     cout<<"\n";
                     cout<<"\n";
                     break;
                case 4:
                     cout<<"\n";
                     p.F2(y.s);
                     cout<<"\n";
                     cout<<"\n";
                     break;
 
 
       }
       }
       cout<<"\n\nWant to continue? - 1/0"<<endl;
                cin>>eF;
}


Пробовал с помощью sprintf :
C++
1
2
3
4
5
6
7
8
9
10
11
12
      class Kodirovanie: public Perestanovka{
            public:
             
                   void F1(char *string){
                   int i, j;
                   
                          for(i=0; i<strlen(string); i++)
                             {
                                   int number = string[i];
                                   sprintf(string[i], "%d", number);
                             }
                 }
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
Текущее время: 16:58. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru