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

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

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

> Задача на линейный поиск, помогите найти ошибку
сообщение
Сообщение #1


Новичок
*

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

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


1. Дан двумерный массив A [NxM] , элементы которого меняются по определенному закону. Определить, есть ли в массиве элемент со значением Q.


PROGRAM PRPV1;
const n=3;m=3;
type Tarr = Array[1..n,1..m] of real;
var
A:Tarr;

i,j:BYTE;
q:real;



BEGIN
FOR i:=1 TO n DO
FOR j:=1 TO m DO
A[i,j]:=30*(n+1-j)+0.2*i; {закон изменения элементов}

FOR i:=1 TO n DO {вывод массива на печать}
BEGIN
FOR j:=1 TO m DO
WRITE(A[i,j]:0:2,' ');
WRITELN;
END;

WRITELN('Enter Q'); {ввод значения для поиска}
READLN(q); {до сюда все работает идеально}

i:=1;
j:=1;
WHILE((i<=n) and (A[i,j]<>q)) do {проблемы начинаются тут}
begin
WHILE((i<=m) and (A[i,j]<>q)) do
j:=j+1;
IF j>m then
i:=i+1;
end;

IF (i > n) AND (j > m) THEN {вывод на печать найденного элемента или сообщение об отсутствии элемента}
WRITELN('not found')
ELSE
WRITELN('found A[',i,',',j,']');

END.



Программа работает идеально, ищет элементы выводит их индексы. Но когда задаешь элемент, которого нет в массиве программа зависает.

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


Гость






Я ж написал, что надо делать в случае двумерного массива... Смотри: допустим, у нас матрица, описанная так:

const
m = 3; n = 5;
var
a: array[1 .. m, 1 .. n] of integer;

, то есть матрица, состоящая из M строк по N элементов в каждой. Вот смотри, что происходит с твоим же кодом, чтобы заставить его работать:
b := 1;  { индекс первого элемента массива }
e := n*m; {e - индекс последнего элемента, где nm = n*m, то есть размерность двумерного массива }

while b <= e do begin
{ ищем элемент на интервале индексов от b до n, включительно }
k := b + (e - b) div 2; { Вот k как раз одномерно... А дальше: }
if x > A[(pred(k) div n) + 1, (pred(k) mod n) + 1] then { <--- Преобразуем k в номер строки и столбца }
i := k + 1
else if x < A[(pred(k) div n) + 1, (pred(k) mod n) + 1] then { <--- здесь - тоже самое }
j := k - 1
else
break; { искомый элемент найден }
end;
...
{ Ну, и ответ печатать в виде: }
writeln('строка = ', (pred(k) div n) + 1, ' столбец = ', (pred(k) mod n) + 1);
Очень много изменений?
 К началу страницы 
+ Ответить 

Сообщений в этой теме


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

 





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