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

Перевод Кода. Шифровка/расшифровка текста - C++

Восстановить пароль Регистрация
Другие темы раздела
C++ Поиск случайного элемента в отсортированном массиве http://www.cyberforum.ru/cpp-beginners/thread1202474.html
Как изменить код так, что бы массив делился не пополам каждый раз, а выбирал число рандомом, после чего задданное число пользователем сравнивал с рандомно выбранным, если больше выбранно то так же выбираем число рандомом в левой части. Короче смысл тот же только массив не пополам делим, а выбираем рандомом число. Вот стандартный код, который делит массив попалам. # include <iostream> using...
C++ В исходную строку добавьте после каждого символа его номер по порядку в алфавите (исправьте пожалуйста) задание ln(1-x)=-, |x|<1 #include <stdio.h> #include <conio.h> #include <math.h> void main(void) { double sumtek,sumpr,e; long int n,x; printf("vvedite tochnost' vichisleniy\n"); scanf("%lf",&e); http://www.cyberforum.ru/cpp-beginners/thread1202467.html
C++ Игра крестики нолики
Помогите пожалуйста. Нужна очень срочно игра крестики-нолили Добавлено через 8 минут Люди спасите!!!
C++ Прошу найти ошибку: принадлежит ли точка области и цикл for
1я задача С помощью условного оператора определить, находится ли точка на плос-кости в замкнутой области. Если находится, то вычислить значение функции f1 (x, y), если нет – то значение функции f2 (x, y). Результаты выдать на экран монитора. Значения x и y ввести с клавиатуры. #include <iostream>; #include <math.h>; using namespace std; float f1(float a, float b) {...
C++ Комбинированный тип данных (struct) http://www.cyberforum.ru/cpp-beginners/thread1202457.html
Описать указанные типы и функции над ними. Продемонстрировать работу всех функций на простых примерах. Тип "время суток" (часы, минуты, секунды). Функции:увеличение времени на 1 секунду; вычисление длительности периода между двумя заданными моментами; определение, к какому периоду суток относится момент времени (утро, день, вечер, ночь). Помогите пожалуйста
C++ Нахождение самого короткого предложения в файле Написать программу, которая в текстовом файле находит самое короткое предложение и удаляет его. Меня напрягает сам алгоритм поиска и сравнения. Помогите, пожалуйста. подробнее

Показать сообщение отдельно
Ar3x
0 / 0 / 0
Регистрация: 23.01.2014
Сообщений: 25
08.06.2014, 12:28     Перевод Кода. Шифровка/расшифровка текста
Имеется код на Delphi, помогите его переделать на С++ пожалуйста.

Delphi
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
177
178
179
180
181
182
183
184
185
186
187
188
189
190
unit Unit1;
 
interface
 
uses
  Windows, Messages, SysUtils, Variants, Classes, Graphics, Controls, Forms,
  Dialogs, StdCtrls, Grids;
 
type
  TForm1 = class(TForm)
    Memo1: TMemo;
    Label1: TLabel;
    Button1: TButton;
    Button2: TButton;
    Edit1: TEdit;
    Label2: TLabel;
    Memo2: TMemo;
    Label4: TLabel;
    Button3: TButton;
    Label5: TLabel;
    Button4: TButton;
    procedure Button1Click(Sender: TObject);
    procedure FormCreate(Sender: TObject);
    procedure Button2Click(Sender: TObject);
    procedure Button3Click(Sender: TObject);
    procedure Button4Click(Sender: TObject);
  private
    { Private declarations }
  public
    { Public declarations }
  end;
 
var
  Form1: TForm1;
  mas_alf: array[1..32] of char = ('А','Б','В','Г','Д','Е','Ж','З','И','Й','К','Л','М','Н','О','П','Р','С','Т','У','Ф','Х','Ц','Ч','Ш','Щ','Ь','Ы','Ъ','Э','Ю','Я');
  tab_Vig: array[1..32,1..32] of Char;
 
implementation
 
{$R *.dfm}
 
procedure TForm1.Button1Click(Sender: TObject);
begin
Close;
end;
 
procedure TForm1.FormCreate(Sender: TObject);
var
  i,j,k,n:integer;
begin
 k:=0;
 n:=k;
 
 for i:=Ord('А')-191 to Ord('Я')-191 do
 begin
   k:=n+1;
   for j:=Ord('А')-191 to Ord('Я')-191 do
    begin
     if k = 33 then
        k:=1;
     tab_vig[i][j]:=mas_alf[k];
     k:=k+1;
    end;
    n:=n+1;
 end;
end;
 
procedure TForm1.Button2Click(Sender: TObject);
var
  key : array [0..255] of Char;
  s:char;
  k:Boolean;
  length_key,length_text,i,j,c,stroka,stolbec: integer;
begin
  Label5.Caption:='';//
  Memo2.Clear;//
  length_key:=Edit1.GetTextLen;
  Edit1.GetTextBuf(key,sizeof(key));
  length_text:=Memo1.GetTextLen;
 
 for i:=Ord('А')-191 to Ord('Я')-191 do
 begin
    for j:=Ord('А')-191 to Ord('Я')-191 do
    begin
      Label5.Caption:= Label5.Caption +'  '+ tab_Vig[i][j];
    end;
    Label5.Caption := Label5.Caption + #13+#10;
 end;
 
 j:=1;
 c:=0;
 k:=false;
 Memo2.Lines.Add('Зашифрованны текст:');
 Memo2.Lines.Add('------------------------');
  for i:= 0 to Memo1.Lines.Count-1 do
  begin
 
     s:=Memo1.Lines[i][j];
     if ((s <> #0) or (s <> #13)) then
     while k = false do
     begin
       if Ord(key[c])>223 then
         stolbec:=Ord(key[c])-32-191
       else
         stolbec:=Ord(s)-191;
       if Ord(s)>223 then
         stroka:=Ord(s)-32-191
       else
         stroka:=Ord(s)-191;
       Memo2.Text:=Memo2.Text+tab_Vig[stroka][stolbec];
       if(c < length_key-1)then
         c:=c+1
       else
         c:=0;
       j:=j+1;
       s:=Memo1.Lines[i][j];
       if(s = #0) then
         k:=true;
     end;
     k:=false;
     j:=1;
  end;
 Memo2.Lines.Add('------------------------');
end;
 
 
procedure TForm1.Button3Click(Sender: TObject);
var
  key : array [0..255] of Char;
  s:char;
  k:Boolean;
  length_key,length_text,i,j,c,stroka,stolbec,q: integer;
begin
  Label5.Caption:='';//
  Memo2.Clear;//
  length_key:=Edit1.GetTextLen;
  Edit1.GetTextBuf(key,sizeof(key));
  length_text:=Memo1.GetTextLen;
  j:=1;
  c:=0;
  k:=false;
  Memo2.Lines.Add('Расшифрованный текст:');
  Memo2.Lines.Add('------------------------');
  for i:= 0 to Memo1.Lines.Count-1 do
  begin
 
     s:=Memo1.Lines[i][j];
     if ((s <> #0) or (s <> #13)) then
     while k = false do
     begin
       if Ord(key[c])>223 then
         stolbec:=Ord(key[c])-32-191
       else
         stolbec:=Ord(s)-191;
       //if Ord(s)>223 then
         //stroka:=Ord(s)-32-191
       //else
         //stroka:=Ord(s)-191;
       for q:=1 to 32 do
       begin
         if tab_Vig[q][stolbec] = s then
         begin
           Memo2.Text:=Memo2.Text+Chr(q+191);
            break;
         end;
       end;
 
       if(c < length_key-1)then
         c:=c+1
       else
         c:=0;
       j:=j+1;
       s:=Memo1.Lines[i][j];
       if(s = #0) then
         k:=true;
     end;
     k:=false;
     j:=1;
  end;
 Memo2.Lines.Add('------------------------');
end;
 
procedure TForm1.Button4Click(Sender: TObject);
var
  f:TextFile;
begin
  Memo2.Lines.SaveToFile('output.txt');
  Application.MessageBox('Файл сохранен в текущую директорию!','Внимание');
end;
end.
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
Текущее время: 21:44. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru