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

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

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

> Модификация двумерных массивов, Поворот матрицы на 90 градусов
FENIX
сообщение 8.12.2004 19:47
Сообщение #1


Новичок
*

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

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


Условия:
1) Массив должен иметь не менее 12 и не более 20 строк и столбцов.
2) Перед обработкой данных необходимо вывести исходный массив на экран.

Задание:
Задан квадратный массив целых чисел в диапазоне от -99 до 99.
Переместить числа так, чтобы эта операция была эквивалентна повороту массива на 90 градусов по часовой стрелке. Результат вывести на экран.

Заранее спасибо.

З.Ы. Всем GL & HF
 Оффлайн  Профиль  PM 
 К началу страницы 
+ Ответить 
 
 Ответить  Открыть новую тему 
Ответов
Гость
сообщение 8.02.2006 23:17
Сообщение #2


Гость






А можно как-то повернуть квадратную матрицу на 90 градусов по часовой стрелке, не использую дополнительный массив?
 К началу страницы 
+ Ответить 
volvo
сообщение 9.02.2006 2:21
Сообщение #3


Гость






Цитата(Гость @ 8.02.2006 22:17)
А можно как-то повернуть квадратную матрицу на 90 градусов по часовой стрелке, не использую дополнительный массив?

И это можно, правда сложнее немного:
const
(* n = 4 *)
n = 5;
type
mx = array[1 .. n, 1 .. n] of integer;

procedure printMatrix(m: mx);
var i, j: integer;
begin
for i := 1 to n do begin
for j := 1 to n do
write(m[i, j]:4);
writeln
end
end;

const
(*
a: mx =
(( 1, 2, 3, 4),
( 5, 6, 7 ,8),
( 9,10,11,12),
(13,14,15,16));
*)
a: mx =
(( 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));

var
i, j, k: integer;
T: integer;
begin
writeln('before:');
printMatrix(a);

writeln;

for k := 1 to n div 2 do
for i := k to n - k do begin
T := a[k, i];
a[k, i] := a[n-i+1, k];
a[n-i+1, k] := a[n-k+1, n-i+1];
a[n-k+1, n-i+1] := a[i, n-k+1];
a[i, n-k+1] := T;
end;

writeln('after:');
printMatrix(a);
end.

Тестировалось на матрицах 4х4 и 5х5...
 К началу страницы 
+ Ответить 
Гость
сообщение 12.04.2011 18:36
Сообщение #4


Гость






Цитата(volvo @ 9.02.2006 2:21) *

И это можно, правда сложнее немного:
const
(* n = 4 *)
n = 5;
type
mx = array[1 .. n, 1 .. n] of integer;

procedure printMatrix(m: mx);
var i, j: integer;
begin
for i := 1 to n do begin
for j := 1 to n do
write(m[i, j]:4);
writeln
end
end;

const
(*
a: mx =
(( 1, 2, 3, 4),
( 5, 6, 7 ,8),
( 9,10,11,12),
(13,14,15,16));
*)
a: mx =
(( 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));

var
i, j, k: integer;
T: integer;
begin
writeln('before:');
printMatrix(a);

writeln;

for k := 1 to n div 2 do
for i := k to n - k do begin
T := a[k, i];
a[k, i] := a[n-i+1, k];
a[n-i+1, k] := a[n-k+1, n-i+1];
a[n-k+1, n-i+1] := a[i, n-k+1];
a[i, n-k+1] := T;
end;

writeln('after:');
printMatrix(a);
end.

Тестировалось на матрицах 4х4 и 5х5...


программа поворачивает не по часовой

 К началу страницы 
+ Ответить 

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


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

 



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