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

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

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

 
 Ответить  Открыть новую тему 
> Задача с процедурами и функциями, две матрицы, транспонировать ту, которая имеет большую сумму на диагон
Mysteo
сообщение 8.12.2008 16:34
Сообщение #1





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

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


program kontr;
uses Crt;
const n=3;
type
vec=array [1..n] Of integer;
mas=array [1..n] of vec;
var
v1,v2:mas; s1,s2:integer;
procedure input (var v:mas);
var i,j:integer;
begin
for i:=1 to n do
for j:=1 to n do
begin
writeln ('vvesti element massiva');
readln (v[i,j]);
end;
end;
Procedure output (v:mas);
var i,j:integer;
begin
for i:=1 to n do
begin
for j:=1 to n do
write (' ',v[i,j]);
writeln;
end;
end;
function sum (v:mas):integer;
var s,i:integer;
begin
s:=0;
For i:=1 To n Do s:=s+v[i, i];
sum:=s;
end;
begin
ClrScr;
write ('vvod massiva 1');
readln;
input (v1);
writeln ('vvod massiva 2');
input (v2);
writeln ('massiv 1:');
output (v1);
writeln ('massiv 2:');
output (v2);
s1:=sum(v1);
s2:=sum(v2);
writeln (s1,' ',s2);
readln;
end.


Здравствуйте, подскажите пожалуйста как организовать транспонирование матрицы в моей программе, не понимаю, надо сделать еще одну процедуру либо функцию или транспонирование можно сделать в функции нахождения суммы?

Сообщение отредактировано: Mysteo - 8.12.2008 16:37
 Оффлайн  Профиль  PM 
 К началу страницы 
+ Ответить 
Archon
сообщение 8.12.2008 17:10
Сообщение #2


Профи
****

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

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


Учитывая, что ты находишь сумму элементов только главной диагонали, то в том же цикле у тебя транспонировать матрицу не выйдет. Вообще, логичнее это сделать в отдельной процедуре.
Для транспонирования нужно просмотреть элементы выше главной диагонали и поменять их значения с симметричными им элементами ниже главной диагонали.
temp := v[i, j];
v[i, j] := v[n - i + 1, n - j + 1];
v[n - i + 1, n - j + 1] := temp;
Но это верно только для квадратных матриц.


--------------------
Close the World...txeN eht nepO
 Оффлайн  Профиль  PM 
 К началу страницы 
+ Ответить 
Lapp
сообщение 8.12.2008 18:02
Сообщение #3


Уникум
*******

Группа: Модераторы
Сообщений: 6 823
Пол: Мужской
Реальное имя: Лопáрь (Андрей)

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


Archon, ты, видимо, что-то не так понял. Транспонировать - это поменять местами a[i,j] и a[j,i].

Верно для любых матриц - как квадратных, так и прямоугольных.


--------------------
я - ветер, я северный холодный ветер
я час расставанья, я год возвращенья домой
 Оффлайн  Профиль  PM 
 К началу страницы 
+ Ответить 
Archon
сообщение 8.12.2008 18:30
Сообщение #4


Профи
****

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

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


Упс, прошу прощения. Lapp верно сказал. Спасибо, что заметил smile.gif


--------------------
Close the World...txeN eht nepO
 Оффлайн  Профиль  PM 
 К началу страницы 
+ Ответить 
Mysteo
сообщение 8.12.2008 18:33
Сообщение #5





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

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


Значит мне надо сделать процедуру транспонирования и в оснвной программе написать что-то вроде

if s1>s2 then trans(v1)
else trans (v2);


?
 Оффлайн  Профиль  PM 
 К началу страницы 
+ Ответить 
Mysteo
сообщение 8.12.2008 18:54
Сообщение #6





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

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



program kontr;
uses Crt;
const n=3;
type
vec=array [1..n] Of integer;
mas=array [1..n] of vec;
var
v1,v2:mas; s1,s2:integer;
procedure input (var v:mas);
var i,j:integer;
begin
for i:=1 to n do
for j:=1 to n do
begin
writeln ('vvesti element massiva');
readln (v[i,j]);
end;
end;
Procedure output (v:mas);
var i,j:integer;
begin
for i:=1 to n do
begin
for j:=1 to n do
write (' ',v[i,j]);
writeln;
end;
end;
function sum (v:mas):integer;
var s,i:integer;
begin
s:=0;
For i:=1 To n Do s:=s+v[i, i];
sum:=s;
end;
procedure trans (var v:mas);
var i,j,vsp:integer;
begin
for i:=1 to j-1 do
begin
for j:=0 to i do
begin
vsp:=v[i,j];
v[i,j]:=v[j,i];
v[j,i]:=vsp;
end;
end;
end;
begin
ClrScr;
write ('vvod massiva 1');
readln;
input (v1);
writeln ('vvod massiva 2');
input (v2);
writeln ('massiv 1:');
output (v1);
writeln ('massiv 2:');
output (v2);
s1:=sum(v1);
s2:=sum(v2);
writeln (s1,' ',s2);
readln;
writeln('transponirovanie');
readln;
if s1>s2 then begin
trans(v1) ;output (v1) ;
end
else begin
trans (v2) ;
output (v2);
end;
readln;
end.


Сделал вроде как надо почему не хочет работать, только сумму считает , а дальше зависаетsad.gif

Добавлено через 18 мин.

program kontr;
uses Crt;
const n=3;
type
vec=array [1..n] Of integer;
mas=array [1..n] of vec;
var
v1,v2:mas; s1,s2:integer;
procedure input (var v:mas);
var i,j:integer;
begin
for i:=1 to n do
for j:=1 to n do
begin
writeln ('vvesti element massiva');
readln (v[i,j]);
end;
end;
Procedure output (v:mas);
var i,j:integer;
begin
for i:=1 to n do
begin
for j:=1 to n do
write (' ',v[i,j]);
writeln;
end;
end;
function sum (v:mas):integer;
var s,i:integer;
begin
s:=0;
For i:=1 To n Do s:=s+v[i, i];
sum:=s;
end;
Procedure trans(var v:mas);
var i,j,temp:integer;
Begin
For i:=1 to (n-1) do
For j:=i+1 to n do
Begin
temp:= v[i,j];
v[i,j]:= v[j,i];
v[j,i]:= temp;
end;
end;

begin
ClrScr;
write ('vvod massiva 1');
readln;
input (v1);
writeln ('vvod massiva 2');
input (v2);
writeln ('massiv 1:');
output (v1);
writeln ('massiv 2:');
output (v2);
s1:=sum(v1);
s2:=sum(v2);
writeln (s1,' ',s2);
readln;
writeln('transponirovanie');
readln;
if s1>s2 then
begin
trans (v1);output(v1);
end
else
begin trans(v2);output(v2);
end;
readln;
end.


Ура, оказывается если разобраться то всё просто , я думал я не сделаю сам!!!)) Всем спасибо кто рассмотрел мою задачку)


Сообщение отредактировано: Mysteo - 8.12.2008 18:55
 Оффлайн  Профиль  PM 
 К началу страницы 
+ Ответить 
Lapp
сообщение 8.12.2008 19:15
Сообщение #7


Уникум
*******

Группа: Модераторы
Сообщений: 6 823
Пол: Мужской
Реальное имя: Лопáрь (Андрей)

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


Procedure trans(var v:mas);
var i,j,temp:integer;
Begin
For i:=1 to (n-1) do
For j:=i+1 to n do
Begin
temp:= v[i,j];
v[i,j]:= v[j,i];
v[j,i]:= temp;
end;
end;



Не успел ответить smile.gif.

Поздравляю, успехов тебе!


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

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

 



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