IPB
ЛогинПароль:

> Прочтите прежде чем задавать вопрос!

1. Заголовок темы должен быть информативным. В противном случае тема удаляется ...
2. Все тексты программ должны помещаться в теги [code=pas] ... [/code].
3. Прежде чем задавать вопрос, см. "FAQ", если там не нашли ответа, воспользуйтесь ПОИСКОМ, возможно такую задачу уже решали!
4. Не предлагайте свои решения на других языках, кроме Паскаля (исключение - только с согласия модератора).
5. НЕ используйте форум для личного общения, все что не относится к обсуждению темы - на PM!
6. Одна тема - один вопрос (задача)
7. Проверяйте программы перед тем, как разместить их на форуме!!!
8. Спрашивайте и отвечайте четко и по существу!!!

> Работа с матрицами, Шифровка текста
Цырилла
сообщение 18.02.2007 20:03
Сообщение #1





Группа: Пользователи
Сообщений: 7
Пол: Женский
Реальное имя: Наталья

Репутация: -  0  +


Необходимо зашифровать текст из 121 буквы, его необходимо записать в квадратную матрицу порядка 11 по стокам, начиная с центра (т. е. с элемента, имеющего индексы 6, 6), а затем по часовой стрелке все остальные символы.
Может кто раньше подобное делал подкажите.
 Оффлайн  Профиль  PM 
 К началу страницы 
+ Ответить 
 
 Ответить  Открыть новую тему 
Ответов
Feagor
сообщение 24.12.2008 22:34
Сообщение #2


ыыыыщщщщщщыыыы
**

Группа: Пользователи
Сообщений: 68
Пол: Мужской
Реальное имя: Иван

Репутация: -  0  +


Необходимо зашифровать текст из 121 буквы, его можно записать в квадратную матрицу порядка 11 по строкам, а затем прочитать по спирали, начиная с центра (т. е. с элемента, имеющего индексы 6, 6).
попытался сделать ипользуя готовый уже код,вот что получилось, но переменная vihod почему-то оказывааетяс пустая, плиз хелп!=)
uses crt;
function incr(var X: integer): integer;
begin
incr := X; inc(X);
end;

const
n =11;
var
n2,i,j,k,w : integer;
a: array[1 .. n, 1 .. n] of char;
text,vihod:string;
begin
clrscr;
writeln('Vvedite text');
readln(Text);
if length(text)<n*n then
for i:=length(text) to n*n do text[i]:='0';
for i:=1 to n do
for j:=1 to n do
a[i,j]:=Text[(i-1)*n+j];
w := 1; n2 := n div 2;

if n mod 2 = 1 then vihod[incr(w)]:=a[n2 + 1, n2 + 1];

for k := 0 to n2 - 1 do begin

for j := n2-k+1 to n-n2+k+1 do vihod[incr(w)]:=a[n2-k,j];
for i := n2-k+1 to n-n2+k+1 do vihod[incr(w)]:=a[i,n-n2+k+1];
for j := n-n2+k downto n2-k do vihod[incr(w)]:=a[n-n2+k+1,j];
for i := n-n2+k downto n2-k do vihod[incr(w)]:=a[i,n2-k];

end;

for i := 1 to n do begin
for j := 1 to n do write(a[i,j]:4);
writeln;
end;
writeln(vihod);
readkey;
end.



Сообщение отредактировано: Feagor - 24.12.2008 22:34


--------------------
Никогда не задавайте вопрос, если не уверены, что хотите получить ответ...
 Оффлайн  Профиль  PM 
 К началу страницы 
+ Ответить 

Сообщений в этой теме


 Ответить  Открыть новую тему 
1 чел. читают эту тему (гостей: 1, скрытых пользователей: 0)
Пользователей: 0

 



- Текстовая версия 20.07.2025 14:34
Хостинг предоставлен компанией "Веб Сервис Центр" при поддержке компании "ДокЛаб"