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

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

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

 
 Ответить  Открыть новую тему 
> упорядочивание строк матриц, помогите, пожалуйста!
сообщение
Сообщение #1





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

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


Люди, помогите. Делаю курсач но что-то не получается. Что я делаю неправильно, подскажите,пожалуйста. Бьюсь над ней уже неделю. Вот условие
Даны две действительные матрицы разной размерности. Используя процедуру упорядочить (переставить) строки матриц по неубыванию сумм тех элементов строк, значения которых лежат в интервале [a,b]. Использование вспомогательных рабочих массивов допускается. Проверить работу программы на тестовом примере. Результаты вывести на печать. Отчет должен содержать: условие задачи, блок-схему алгоритма работы программы. Программу, тестовые исходные данные и результаты работы программы.
а вот это мое предполагаемое решение
Код

program kursovaya;
type vect=array[1..7,1..7] of integer;
var bm,cm:vect;  
rv1,rh1,rv2,rh2,i,j,k,p,s,aq,bq,q:integer;
procedure proc(var a:vect;var h,v:integer);
var b :array [1..7] of integer;
begin
for j:=1 to v do begin  
q:=0;
for i:=1 to h do
if (a[i,j]>aq) or (a[i,j]<bq) then q:=q+a[i,j];
b[j]:=q;
end;
for i:=1 to v-1 do  
begin  
k:=i;  
for j:=i to v do  
if b[k]<b[j] then k:=j;  
for s:=1 to h do  
begin  
p:=a[s,k];  
a[s,k]:=a[s,i];  
a[s,i]:=p;  
end;  
end;  
end;  
procedure vvod(var f:vect;var h,v:integer);  
begin  
for i:=1 to v do
for j:=1 to h do  
read(f[j,i]);  
end;  
procedure vyvod(var f:vect;var h,v:integer);
begin
for i:=1 to v do  
begin
for j:=1 to h do  
write(f[j,i]);  
writeln;  
end;  
end;  
begin  
read(rv1,rh1);
read(rv2,rh2);
read(aq,bq);  
vvod(bm,rv1,rh1);  
vvod(cm,rv2,rh2);  
proc(bm,rv1,rh1);  
proc(cm,rv2,rh2);  
vyvod(bm,rv1,rh1);  
vyvod(cm,rv2,rh2);  
end.

Буду очень благодарен, если хотя бы подскажите.

Сообщение отредактировано: klim -
 Оффлайн  Профиль  PM 
 К началу страницы 
+ Ответить 
сообщение
Сообщение #2


Гость






Естественно, при таких названиях переменных можно и полгода сидеть - ничего не получится... Ты для себя уже реши, что у тебя есть что, где "ширина" матрицы, а где ее "высота", и не надо все время менять их местами! Так уж принято, что ПЕРВЫМ индексом идет номер строки, а вторым - номер столбца..

Еще одно: ты написал про вещественную матрицы, а используешь целочисленную... Это как понимать?

Вот работающая программа. Для теста - задавал значения прямо в коде:

program kursovaya;


type
vect = array[1..7, 1..7] of integer;

var bm,cm:vect;
rv1,rh1,rv2,rh2,i,j,k,p,s,aq,bq,q:integer;


procedure proc(var a: vect; h, v: integer);

function get_sum(line: integer): integer;
var sum, i: integer;
begin
sum := 0;

for i := 1 to h do
if (a[line, i] > aq) and (a[line, i] < bq)
then sum := sum + a[line, i];

get_sum := sum;
end;

begin

for i := 1 to v do
for j := v downto i + 1 do
if get_sum(j - 1) > get_sum(j) then

for k := 1 to h do begin

p := a[j - 1, k]; a[j - 1, k] := a[j, k]; a[j, k] := p;

end;

end;

procedure vvod(var f:vect;var h,v:integer);
begin
for i:=1 to v do
for j:=1 to h do begin
{ read(f[j,i]); }
f[i, j] := random(10);
end;
end;

procedure vyvod(var f:vect;var h,v:integer);
begin
for i:=1 to v do begin
for j:=1 to h do write(f[i, j]:4);
writeln;
end;
end;

begin
{ readln(rv1,rh1); }
rv1 := 5; rh1 := 5;
{ readln(rv2,rh2); }
rv2 := 4; rh2 := 4;
{ readln(aq,bq); }
aq := 0; bq := 10;

vvod(bm,rv1,rh1); { вводим }
vyvod(bm,rv1,rh1); { печатаем для проверки }

vvod(cm,rv2,rh2);
vyvod(cm,rv2,rh2);

proc(bm,rv1,rh1); { обрабатываем }
proc(cm,rv2,rh2);

vyvod(bm,rv1,rh1); { выводим результат }
vyvod(cm,rv2,rh2);
end.



Сообщение отредактировано: volvo -
 К началу страницы 
+ Ответить 
сообщение
Сообщение #3





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

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


Слушай, спасибо большое. Просто обязан тебе. А на счет путаницы у меня был другой вариант решения, но путем постепенных изменений(в поиске ошибки) получилось то, что ты видел. Еще раз спасибо.
 Оффлайн  Профиль  PM 
 К началу страницы 
+ Ответить 

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

 





- Текстовая версия 29.03.2024 7:13
500Gb HDD, 6Gb RAM, 2 Cores, 7 EUR в месяц — такие хостинги правда бывают
Связь с администрацией: bu_gen в домене octagram.name