![]() |
1. Заголовок темы должен быть информативным. В противном случае тема удаляется ...
2. Все тексты программ должны помещаться в теги [code=pas] ... [/code].
3. Прежде чем задавать вопрос, см. "FAQ", если там не нашли ответа, воспользуйтесь ПОИСКОМ, возможно такую задачу уже решали!
4. Не предлагайте свои решения на других языках, кроме Паскаля (исключение - только с согласия модератора).
5. НЕ используйте форум для личного общения, все что не относится к обсуждению темы - на PM!
6. Одна тема - один вопрос (задача)
7. Проверяйте программы перед тем, как разместить их на форуме!!!
8. Спрашивайте и отвечайте четко и по существу!!!
![]() ![]() |
![]() |
Макс |
![]()
Сообщение
#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. |
Гость |
![]()
Сообщение
#2
|
Гость ![]() |
procedure naimpoloz1; Вот где твоя ошибка, ты ищешь сначала наименьший элемент массива, а потом этот же наименьший элемент сравниваешь с другими (понятно, что меньше его не будет.) Совет такой: изменить условие, при чем, minp2:=32768; If (a[i,j]<minp2) and (a[i,j]<>minp1) Ты когда-нибудь будешь тегами пользоваться? Сообщение отредактировано: volvo - 24.12.2005 22:41 |
Гость |
![]()
Сообщение
#3
|
Гость ![]() |
Слушай, спасибо тебе огромное !
P.S.ошибка действительно очент глупая ![]() |
Гость |
![]()
Сообщение
#4
|
Гость ![]() |
Да всегда пожалуйста
|
volvo |
![]()
Сообщение
#5
|
Гость ![]() |
Цитата изменить условие, при чем, minp2:=32768; И есть вероятность при компиляции в Дельфях нарваться на проблему (такое уже было, ищи по форуму)...Не просто так, видимо ввели константу MaxInt... minP2 := maxInt; { <--- Избавляет от привязки к компилятору } |
Макс |
![]()
Сообщение
#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. |
Макс |
![]()
Сообщение
#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. |
Макс |
![]()
Сообщение
#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; |
Макс |
![]()
Сообщение
#9
|
Гость ![]() |
Need help, please!
|
volvo |
![]()
Сообщение
#10
|
Гость ![]() |
Макс, замени свои процедуры на эти:
procedure naimpoloz1; НО!!! Это будет работать корректно только тогда, когда в массиве есть по крайней мере 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 |
Макс |
![]()
Сообщение
#11
|
Гость ![]() |
![]() |
![]() ![]() |
![]() |
Текстовая версия | 21.07.2025 10:32 |