С Новым годом! Форум программистов, компьютерный форум, киберфорум
Pascal (Паскаль)
Войти
Регистрация
Восстановить пароль
Карта форума Темы раздела Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 5.00/7: Рейтинг темы: голосов - 7, средняя оценка - 5.00
Goldeeeeeeen !
245 / 237 / 186
Регистрация: 15.10.2011
Сообщений: 457
1

Перестановка бит в коде исходного текста.

26.01.2012, 21:37. Показов 1351. Ответов 1
Метки нет (Все метки)

Author24 — интернет-сервис помощи студентам
Шифрование методом перестановок.Перестановка бит в коде исходного текста.Разбивка на блоки – по 12 бит.(шифров.,расшифр.).

Помогите пожалуйста...

Добавлено через 2 часа 19 минут
Зашифровка есть
Pascal
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
const mas: array[1..12] of integer = (2,1,6,5,12,7,8,3,10,11,9,4); //индексы перестановки
 
var i,j,n,k,d: integer;
s,s1: string;
c: char;
 
function IntToBin(k: integer): string;
var i: integer;
s: string;
begin
s:='';
for i:=11 downto 0 do
if (k div trunc(exp(i*ln(2))) = 1) then
begin
s:=s+'1';
k:=k-trunc(exp(i*ln(2)));
end
else
s:=s+'0';
result:=s;
end;
 
begin
writeln ('Введите последовательность символов');
readln (s);
n:=length(s);
write('Зашифрованный текст в бинарном виде: ');
for i:=1 to n do
begin
j:=ord(s[i]);
s1:=IntToBin(j);
c:=s1[mas[1]];
for k:=1 to 11 do
s1[mas[k]]:=s1[mas[k+1]];
s1[mas[12]]:=c;
write(s1);
end;
end.
Вот мне бы еще расшифровку...
0
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
26.01.2012, 21:37
Ответы с готовыми решениями:

Перестановка в конец текста строк с заданным символом
Перестановка в конец текста строк с заданным символом. В программе предусмотреть ввод с терминала...

Перестановка бит в коде исходного текста
Помогите решить задачу Нужно осушествить кодировку исходного текста(размер текста заранее...

Перестановка бит в числе
Необходимо переставить биты в числе, не понимаю как это сделать. Задание: переставить первый и...

Перестановка пар бит в двух числах и битовые операции
Добрый день! Есть такая задачка. "Написать программу, которая позволит ввести два числа a и b...

1
Goldeeeeeeen !
245 / 237 / 186
Регистрация: 15.10.2011
Сообщений: 457
28.01.2012, 17:25  [ТС] 2
Может кому пригодится...

Pascal
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
var i,j,n,k,l,m,d: integer;
s,s1,s4,s5,s7: string;  key:array[1..12] of integer;
c: char;     s2,s3,s6:array[1..100] of string;
 
//***********************************************************
//функция перевода в двоичную систему счисления из десятичной
//***********************************************************
function IntToBin(Value: integer): string;
var
  i: integer;
const
  digits: integer = 8;
begin
  result := '';
  for i := 0 to Digits - 1 do
  if Value and (1 shl i) > 0
  then result := '1' + result
  else result := '0' + result;
end;
//***********************************************************
 
//***********************************************************
//функция перевода в десятичную из двоичной сист. счисления
//***********************************************************
function BinToInt(Value: String): LongInt;
var
  I, Size: Integer;
begin
  Result := 0;
  Size := Length(Value);
  I := 1;
  while I <= Size do begin
    if Value[i] = '1' then Result := Result + (1 shl (Size - I));
    Inc(I);
  end;
end;
//***********************************************************
 
 
begin
writeln ('Добрый день,уважаемый юзер!');
writeln ('Что желаете? ');
writeln ('Хотите зашифровать текст ? Нажмите 1.');
writeln ('Хотите расшифровать текст ? Нажмите 2.');
write ('Выбор за вами... : ');
readln(j);
writeln; writeln;
 
if j=1 then begin
writeln ('Введите последовательность символов');
readln(s);
writeln ('Введите ключ для шифровки (12 цифр в диапазоне [1..12]): ');
for i:=1 to 12 do
readln(key[i]);
n:=length(s);
s1:='';
for i:=1 to n do
begin
j:=ord(s[i]);
s1:=s1+IntToBin(j);
end;
 
j:=1;   s2[1]:='';
for i:=1 to length(s1) do
begin
s2[j]:=s2[j]+s1[i];
if i mod 12=0 then begin j:=j+1; s2[j]:=''; end;
end;
writeln('Текст по блокам в бинарном виде (в блоке по 12 бит): ');
for i:=1 to j do
writeln(s2[i]);
 
writeln('Зашифрованый текст по блокам в бинарном виде (в блоке по 12 бит): ');
for i:=1 to j-1 do
begin
s3[i]:='';
for d:=1 to 12 do
begin
s4:=s2[i];
s3[i]:=s3[i]+s4[key[d]];
end;
writeln(s3[i]);
s5:=s5+s3[i];
end;
writeln; writeln;
end
else begin
 
writeln; writeln;
writeln ('Введите ключ для расшифровки (12 цифр в диапазоне [1..12]): ');
for i:=1 to 12 do
readln(key[i]);
 
writeln ('Введите количество блоков(по 12 бит): ');
readln(j);
 
writeln('Введите зашифрованный текст по блокам в бинарном виде (в блоке по 12 бит): ');
for i:=1 to j do
readln(s2[i]);
 
s7:='000000000000'; s5:='';
writeln('Расшифрованый текст по блокам в бинарном виде (в блоке по 12 бит): ');
for i:=1 to 4 do
begin
s3[i]:='';
for d:=1 to 12 do
begin
s4:=s2[i];;
s7[key[d]]:=s4[d];
end;
s3[i]:=s7;
writeln(s3[i]);
s5:=s5+s3[i];
end;
 
 
j:=1;
for i:=1 to length(s5) do
begin
s6[j]:=s6[j]+s5[i];
if i mod 8=0 then begin j:=j+1; s6[j]:=''; end;
end;
 
writeln;
writeln('Расшифрованый текст : ');
for i:=1 to j do
write(chr(BinToInt(s6[i])));
end;
end.
0
28.01.2012, 17:25
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
28.01.2012, 17:25
Помогаю со студенческими работами здесь

Сдвиговые операции: установить регистр EBХ в значение 1, если 14-й бит исходного числа равен 1
Друзья, как сделать это чудо, я не понимаю, что к чему? Расскажите пожалуйста подробнее! 1. В...

Несостыковка с сохранением последовательности бит в файл в коде Хаффмена
Имеется бинарный файл, в нем список чисел по 8 бит (np.int8) Они делятся на 2 части по 4 бита Эти...

перестановка n символов текста
Доброго времени суток! Помогите, пажалуйста, написать программу, которая переставляет n-ое...

Дано число в двоичном коде поменять местами третий бит с пятым. Результат умножить на 8 и проинвентировать.
Дано число в двоичном коде поменять местами третий бит с пятым. Результат умножить на 8 и...


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

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2024, CyberForum.ru