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

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

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

> Сумматор по периметру, пожалуйста помогите
Po1son
сообщение 2.12.2007 13:23
Сообщение #1





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

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


вводится матрица А(n,n)
составить программу подсчета сумм значений элементов этой матрицы, образующих квадрат по уменьшению на единицу периметра
исходную матрицу и суммы вывести
 Оффлайн  Профиль  PM 
 К началу страницы 
+ Ответить 
 
 Ответить  Открыть новую тему 
Ответов
klem4
сообщение 2.12.2007 14:01
Сообщение #2


Perl. Just code it!
******

Группа: Модераторы
Сообщений: 4 100
Пол: Мужской
Реальное имя: Андрей

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


Что-то вроде этого:


const
n = 6;

type
TMatrix = array [1..n, 1..n] of Integer;

procedure Create(var mx: TMatrix);
var
i, j: Integer;
begin
randomize;

for i := 1 to n do
for j := 1 to n do
mx[i, j] := random(10);
end;

procedure Print(const mx: TMatrix);
var
i, j: Integer;
begin
for i := 1 to n do begin
writeln;
for j := 1 to n do write(mx[i, j]:2);
end;
writeln;writeln;
end;

function SquareSum(const mx: TMatrix; const deep: Integer): Integer;
var
s, i: Integer;
begin
s := 0;

for i := deep to n - deep + 1 do
s := s + mx[deep, i] + mx[n - deep + 1, i];

for i := deep + 1 to n - deep do
s := s + mx[i, deep] + mx[i, n - deep + 1];

SquareSum := s;
end;

var
mx: TMatrix;
i: Integer;

begin
Create(mx);
Print(mx);

for i := 1 to n div 2 do
writeln('deep = ', i, ' square_sum = ', SquareSum(mx, i));
end.


--------------------
perl -e 'print for (map{chr(hex)}("4861707079204E6577205965617221"=~/(.{2})/g)), "\n";'
 Оффлайн  Профиль  PM 
 К началу страницы 
+ Ответить 

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


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

 



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