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

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

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

> Массив, Помогите исправить ошибку!!!
Макс
сообщение 24.12.2005 20:58
Сообщение #1


Гость






В заданном двумерном массиве поменять местами минимальные элементы среди положительных.

Проблема в том что не могу найти второй наименьший элемент(приравнивается к первому)

Помогите еси не трудно
Код

uses crt;
var a:array[1..50,1..50] of integer;
    i,j,m,n,minp1,minp2,min_i,min_j:integer;
    key:char;
procedure zapolnenie;
begin
  for i:=1 to n do
  for j:=1 to m do
  begin
  A[i,j]:=random(20);
end;
end;

procedure vyvod;
begin
    for i:=1 to n do begin
    for j:=1 to m do
    write(' ',a[i,j]);
    writeln;
    end;
end;

procedure naimpoloz1;
begin
  minp1:=a[1,1];
  min_i:=1;min_j:=1;
  for i:=1 to n do
  for j:=1 to m do
  begin
  if a[i,j]<minp1 then minp1:=a[i,j];
  if a[min_i,min_j]>a[i,j] then begin
  min_i:=i;
  min_j:=j;
  end;
  end;
  writeln(minp1);
  writeln(min_i,'   ',min_j);
  end;

procedure naimpoloz2;
begin
  minp2:=a[min_i,min_j];
  for i:=1 to n do
  for j:=1 to m do
  begin
  if a[i,j]<minp2 then minp2:=a[i,j];
  end;
  writeln(minp2);
end;

procedure obmen;
begin
..........
end;

begin
    repeat
    clrscr;
    textcolor(white);
    writeln('vvedite kol-vo strok');
    readln(n);
    writeln('vvedite kol-vo stolbcov');
    readln(m);
    zapolnenie;
    vyvod;
    naimpoloz1;
    naimpoloz2;
    obmen;
    writeln('Dla vyhoda nazmite N');
    key:=readkey;
    until upcase (key)='N';
end.
 К началу страницы 
+ Ответить 
 
 Ответить  Открыть новую тему 
Ответов(1 - 10)
Гость
сообщение 24.12.2005 22:08
Сообщение #2


Гость






procedure naimpoloz1;
begin
minp1:=a[1,1];
min_i:=1;min_j:=1;
for i:=1 to n do
for j:=1 to m do
begin
if a[i,j]<minp1 then minp1:=a[i,j];
if a[min_i,min_j]>a[i,j] then begin
min_i:=i;
min_j:=j;
end;
end;
writeln(minp1);
writeln(min_i,' ',min_j); { <--- Вот тут !!! }
end;

procedure naimpoloz2;
begin
minp2:=a[min_i,min_j];
for i:=1 to n do
for j:=1 to m do
begin
if a[i,j]<minp2 then minp2:=a[i,j]; { <--- Вот тут !!! }
end;
writeln(minp2);
end;

Вот где твоя ошибка, ты ищешь сначала наименьший элемент массива, а потом этот же наименьший элемент сравниваешь с другими (понятно, что меньше его не будет.) Совет такой:
изменить условие, при чем, minp2:=32768;
If (a[i,j]<minp2) and (a[i,j]<>minp1)

Ты когда-нибудь будешь тегами пользоваться?

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


Гость






Слушай, спасибо тебе огромное !
P.S.ошибка действительно очент глупая yes2.gif
 К началу страницы 
+ Ответить 
Гость
сообщение 24.12.2005 22:16
Сообщение #4


Гость






Да всегда пожалуйста
 К началу страницы 
+ Ответить 
volvo
сообщение 24.12.2005 22:44
Сообщение #5


Гость






Цитата
изменить условие, при чем, minp2:=32768;
И есть вероятность при компиляции в Дельфях нарваться на проблему (такое уже было, ищи по форуму)...

Не просто так, видимо ввели константу MaxInt...
minP2 := maxInt; { <--- Избавляет от привязки к компилятору }
 К началу страницы 
+ Ответить 
Макс
сообщение 24.12.2005 22:48
Сообщение #6


Гость






Немного исправил, и кстати ещё один вопрос: как вывести новую матрицу с замененными элементами

Код
uses crt;
var a:array[1..50,1..50] of integer;
    i,j,m,n,minp1,minp2,min:integer;
    key:char;
procedure zapolnenie;
begin
  for i:=1 to n do
  for j:=1 to m do
  begin
  A[i,j]:=random(20);
end;
end;

procedure vyvod;
begin
    for i:=1 to n do begin
    for j:=1 to m do
    write(' ',a[i,j]);
    writeln;
    end;
end;

procedure naimpoloz1;
begin
  minp1:=a[1,1];
  for i:=1 to n do
  for j:=1 to m do
  begin
  if a[i,j]<minp1 then minp1:=a[i,j];
  end;
  writeln(minp1);
end;

procedure naimpoloz2;
begin
  minp2:=100;
  for i:=1 to n do
  for j:=1 to m do
  begin
  if (a[i,j]<minp2) and (a[i,j]<>minp1) then minp2:=a[i,j];
  end;
  writeln(minp2);
end;

procedure swap;
begin
  minp2:=minp2-minp1;
  minp1:=minp1+minp2;
  minp2:=minp1-minp2;
end;

begin
    repeat
    clrscr;
    textcolor(white);
    writeln('vvedite kol-vo strok');
    readln(n);
    writeln('vvedite kol-vo stolbcov');
    readln(m);
    zapolnenie;
    vyvod;
    naimpoloz1;
    naimpoloz2;
    swap;
    writeln(minp1);writeln(minp2);
    writeln('Dla vyhoda nazmite N');
    key:=readkey;
    until upcase (key)='N';
end.
 К началу страницы 
+ Ответить 
Макс
сообщение 24.12.2005 23:47
Сообщение #7


Гость






Всем огромное спасибо - во всём разобрался.
Кстати вот выкладываю полное решение.

Код

uses crt;
var a:array[1..50,1..50] of integer;
    i,j,m,n,minp1,minp2,min:integer;
    key:char;
procedure zapolnenie;
begin
  for i:=1 to n do
  for j:=1 to m do
  begin
  A[i,j]:=random(20);
end;
end;

procedure vyvod;
begin
    for i:=1 to n do begin
    for j:=1 to m do
    write(' ',a[i,j]);
    writeln;
    end;
end;

procedure naimpoloz1;
begin
  minp1:=a[1,1];
  for i:=1 to n do
  for j:=1 to m do
  begin
  if a[i,j]<minp1 then minp1:=a[i,j];
  end;
  writeln(minp1);
end;

procedure naimpoloz2;
begin
  minp2:=maxint;
  for i:=1 to n do
  for j:=1 to m do
  begin
  if (a[i,j]<minp2) and (a[i,j]<>minp1) then minp2:=a[i,j];
  end;
  writeln(minp2);
end;

procedure swap;
begin
  for i:=1 to n do
  for j:=1 to m do
  begin
  minp2:=minp2-minp1;
  minp1:=minp1+minp2;
  minp2:=minp1-minp2;
  if a[i,j]=minp1 then a[i,j]:=minp2;
  if a[i,j]=minp2 then a[i,j]:=minp1;
end;
end;

{main}
begin
    repeat
    clrscr;
    textcolor(white);
    writeln('vvedite kol-vo strok');
    readln(n);
    writeln('vvedite kol-vo stolbcov');
    readln(m);
    zapolnenie;
    vyvod;
    naimpoloz1;
    naimpoloz2;
    swap;
    vyvod;
    writeln('Dla vyhoda nazmite N');
    key:=readkey;
    until upcase (key)='N';
end.
 К началу страницы 
+ Ответить 
Макс
сообщение 25.12.2005 0:53
Сообщение #8


Гость






Кстати что надо исправить, чтобы пограмма работала правильно, если массив будет заполнятся отрицательными и положительными числами?
например при генерировании случ чисел от -10 до 10
Код
begin
  for i:=1 to n do
  for j:=1 to m do
  begin
  A[i,j]:=random(21)-10;
end;
end;
 К началу страницы 
+ Ответить 
Макс
сообщение 25.12.2005 9:51
Сообщение #9


Гость






Need help, please!
 К началу страницы 
+ Ответить 
volvo
сообщение 25.12.2005 10:04
Сообщение #10


Гость






Макс, замени свои процедуры на эти:
procedure naimpoloz1;
begin
minp1:=maxint;
for i:=1 to n do
for j:=1 to m do
begin
if (a[i,j]>0) and (a[i,j]<minp1) then minp1:=a[i,j];
end;
writeln(minp1);
end;

procedure naimpoloz2;
begin
minp2:=maxint;
for i:=1 to n do
for j:=1 to m do
begin
if (a[i,j]>0) and (a[i,j]<minp2) and (a[i,j]<>minp1) then minp2:=a[i,j];
end;
writeln(minp2);
end;

НО!!! Это будет работать корректно только тогда, когда в массиве есть по крайней мере 2 разных положительных элемента...

Вот лог программы:
Цитата
vvedite kol-vo strok
5
vvedite kol-vo stolbcov
5
1 2 5 7 2
8 1 7 -2 3
3 -2 -1 -4 8
-9 10 -5 -2 0
6 7 1 0 1
1
2
2 1 5 7 2
8 2 7 -2 3
3 -2 -1 -4 8
-9 10 -5 -2 0
6 7 2 0 2
Dla vyhoda nazmite N
 К началу страницы 
+ Ответить 
Макс
сообщение 25.12.2005 10:06
Сообщение #11


Гость






good.gif Volvo, огромное спасибо!
 К началу страницы 
+ Ответить 

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

 



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