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

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

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

> сортировка по столбцам, сортировка двумерного массива по столбцам
nesta_diima
сообщение 2.11.2011 23:50
Сообщение #1





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

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


Подскажите с сортировкой двумерного массива по столбцам, что-то не выходит. Вот наработка

uses crt;
const
nmax=100;
type
arr=array[0..nmax,0..nmax] of integer;
var
z:arr;
s,i,j,buf,n,m,p:integer;
begin
Writeln('ВВод матрицы');
writeln('Ввод кол-вo строк');
readln(n);
writeln('Ввод кол-во стоблцов');
readln(m);
for i:=1 to n do
begin
for j:=1 to m do
begin
Writeln('Ввод ',i,' ',j,'элемента матрицы');
readln(z[i,j]);
end;
end; for j:=1 to m do
begin
for i:=1 to n do
if z[i,j]>z[i+1,j] then
begin
buf:=z[i,j];
z[i,j]:=z[i+1,j];
z[i+1,j]:=buf;
end; end;
for i:=1 to n do
for j:=1 to m do
begin
write(z[i,j]:4);
if j=m then writeln();
end;

end.
 Оффлайн  Профиль  PM 
 К началу страницы 
+ Ответить 
 
 Ответить  Открыть новую тему 
Ответов(1 - 4)
IUnknown
сообщение 3.11.2011 12:57
Сообщение #2


a.k.a. volvo877
*****

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

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


"Пузырек" одним циклом? Оригинально, но неправильно. Циклов должно быть 2:

   for j:=1 to m do { Это - внешний цикл, перебирающий столбцы }
begin
{ А для каждого столбца - еще 2 цикла: }
for k:=1 to n do for i := n downto k+1 do
if z[i-1,j]>z[i,j] then
begin
buf:=z[i,j];
z[i,j]:=z[i-1,j];
z[i-1,j]:=buf;
end;
end;
, тогда будет сортировать элементы столбца по возрастанию...
 Оффлайн  Профиль  PM 
 К началу страницы 
+ Ответить 
TarasBer
сообщение 3.11.2011 13:04
Сообщение #3


Злостный любитель
*****

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

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


> "Пузырек" одним циклом?

Думаю, это не специально.
Потому что отступы и форматирование соблюдать надо.
У тебя тоже то ли бегин пропущен, то ли енд лишний.

Сообщение отредактировано: TarasBer - 3.11.2011 13:05


--------------------
 Оффлайн  Профиль  PM 
 К началу страницы 
+ Ответить 
IUnknown
сообщение 3.11.2011 13:28
Сообщение #4


a.k.a. volvo877
*****

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

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


Цитата
У тебя тоже то ли бегин пропущен, то ли енд лишний.
всего там хватает, просто при копировании перенеслось как-то непонятно. end должен быть на 3 символа левее...
 Оффлайн  Профиль  PM 
 К началу страницы 
+ Ответить 
TarasBer
сообщение 3.11.2011 15:43
Сообщение #5


Злостный любитель
*****

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

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


Вот поэтому я или обрамляю лишний раз парой begin-end, либо пишу ВЕСЬ заголовок в одну строку

for k:=1 to n do for i := n downto k+1 do if z[i-1,j]>z[i,j] then begin
buf:=z[i,j];
z[i,j]:=z[i-1,j];
z[i-1,j]:=buf;
end;


Про одну строку - это скорее из вредных советов, но в этом тоже есть свой смысл - весь заголовок по смыслу является одним выражением "для всех пар, для которых так-то, сделать..."
Ещё вариант - не сдвигаться на 2 на if

Сообщение отредактировано: TarasBer - 3.11.2011 15:43


--------------------
 Оффлайн  Профиль  PM 
 К началу страницы 
+ Ответить 

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

 



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