17.10.2016, 19:24 | #1 (permalink) |
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. |
17.10.2016, 19:24 | |
Helpmaster
Member
Регистрация: 08.03.2016
Сообщений: 0
|
Вы можете побыстрее решить эту проблему, если ознакомитесь с похожими постами Помогите с задачей по Delphi Помогите с графиком в Delphi Помогите исправить код Помогите исправить программу на Delphi Помогите решить в Delphi |
Ads | |
Member
Регистрация: 31.10.2006
Сообщений: 40200
Записей в дневнике: 0
Сказал(а) спасибо: 0
Поблагодарили 0 раз(а) в 0 сообщениях
Репутация: 55070
|
|
|