Показать сообщение отдельно
Старый 17.10.2016, 19:24   #1 (permalink)
Smile188
Member
 
Регистрация: 13.10.2016
Сообщений: 15
Сказал(а) спасибо: 0
Поблагодарили 0 раз(а) в 0 сообщениях
Репутация: 10
По умолчанию Помогите исправить. Delphi

Помогите немножко исправить
Смысл таков, что нужно самим вводить кол-во столбцов и строк в матрице

Задача:
открытый текст записывается в матрицу по определенному ключу k1,
определяющему порядок записи открытого текста в строки матрицы при
шифровании. Шифртекст образуется при считывании из этой матрицы по
ключу k2, определяющему, в каком порядке записывается информация из
столбцов матрицы. Для реализации такого варианта перестановки можно не использовать непосредственно матрицу, а осуществлять перерасчет коэф- фициентов.

Код:
program Project2;

{$APPTYPE CONSOLE}

uses
Windows, 
SysUtils;
    Const
    q=100;
    h=100;
var
Text,Text_1,Text_2,text_3,S:String;
Textmatr:Array[1..q,1..h] of Char;
i,j,k,kolsimvolov,code:integer;
key1:array[1..q] of Byte;
key2:array[1..h] of Byte;
p,t,m:Boolean;
  r,b:integer;
Begin 
SetConsoleCP(1251); 
SetConsoleOutputCP(1251); 

repeat

     write ('введите кол-во строк в матрице : ');
  readln (r);
  write ('введите кол-во столбцов в матрице : ');
  readln (b);

Write('Введи текст для кодировки: '); 
Readln(Text); 
kolsimvolov:=Length(text); 
m:=True; 
if kolsimvolov>r*b then
m:=False; 
if not(m) then
writeln('количество символов не должно превышать ',r*b);
until m; 
If (kolsimvolov div (r*b))<> 1 then //если кол-во символов текста не кратно кол-ву символов в блоке дополняем его пробелами
repeat
begin 
text:=text+' ';
Inc(kolsimvolov);   end;
until kolsimvolov=r*b;

Repeat
 Write('Ведите ключ 1 ', q,' без пробелов): ');
  Readln(S);
    for i:=1 to q do
     Val(S[i],key1[i],Code);
    p:=true;


p:=true;
for i:=1 to q-1 do
    for j:=i+1 to q do
if (key1[i]=key1[i+1]) then 
p:=false;
If Not(p) then 
writeln('Все символы должны быть различными!'); 
Until p; 
Repeat
Write('введите ключ 2 ', h, ' цифры без пробелов): ');
    Readln(S);
    for i:=1 to h do
Val(S[i],key2[i],Code);
    p:=true;
    for i:=1 to h-1 do
     for j:=i+1 to h do
      if (key2[i]=key2[j]) then t:=false;
     If Not(t) then writeln('Все цифры должны быть различными!');
  Until  t;
  Writeln;


//----------------------------------------------------—
   For i:=1 to q do
  For j:=1 to h do
   Textmatr[key1[i],j]:=Text[(i-1)*h+j];

Writeln(' k1\k2 ');
For i:=1 to q do
  begin
    Write('    ',i,'    ');
    For j:=1 to h do
    write('    ',textmatr[i,j],'    ');
    Writeln;
  end;
//----------------------------------------------------— 
Text_1:='';
 For j:=1 to k do
  for i:=1 to q do
  begin
    S:=textmatr[i,key2[j]];
    Text_1:=Text_1+S;
end; 
Writeln('Закодированный текст:',' ',text_1); 
//-----------------------------------------------------— 
Text_2:=''; 
For j:=1 to h do
begin 
S:=Copy(Text_1,(key2[j]-1)*q+1,q);
Text_2:=Text_2+S; 
end;
Text_3:=''; 
For i:=1 to q do
For j:=1 to h do
begin 
S:=Copy(Text_2,(j-1)*q+key1[i],1);
Text_3:=Text_3+S;
end; 
Writeln('Раскодированный текст:',' ',Text_3);
//-----------------------------------------------------—
Writeln;
Readln;
End.
Smile188 вне форума   Ответить с цитированием
Ads

Яндекс

Member
 
Регистрация: 31.10.2006
Сообщений: 40200
Записей в дневнике: 0
Сказал(а) спасибо: 0
Поблагодарили 0 раз(а) в 0 сообщениях
Репутация: 55070