Форум программистов, компьютерный форум, киберфорум
Pascal (Паскаль)
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.69/88: Рейтинг темы: голосов - 88, средняя оценка - 4.69
0 / 0 / 0
Регистрация: 27.12.2015
Сообщений: 18

Как проверить принадлежит ли число массиву?

11.01.2016, 14:53. Показов 17161. Ответов 16
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Дан массив (integer), вводится число и необходимо узнать, есть ли оно в массиве.
0
Лучшие ответы (1)
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
11.01.2016, 14:53
Ответы с готовыми решениями:

Проверить, принадлежит ли введенный элемент X массиву A с указанными пользователем элементами
Помогите п-жста с этим: 1. Проверить, принадлежит ли введенный элемент X массиву A с указанными пользователем элементами. 2. Если да,...

Определить,принадлежит ли заданный элемент массиву
Определить принадлежит ли заданный элемент массиву!!! помогите плиз срочно

Как проверить принадлежит ли точка прямой?
Существует точка с координатами (Xt,Yt) прямой A(X1,Y1)B(X2,Y2)?

16
5 / 5 / 10
Регистрация: 08.01.2016
Сообщений: 80
11.01.2016, 15:03
Pascal
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
const n=10;
begin
randomize;
var logick:boolean;
var a:array [1..n] of integer;
 
for var i:=1 to n do a[i]:=random(10);
println('Массив');
writeln(a);
 
var c:=readInteger('Введите число: ');
for var i:=1 to n do begin
                     if (c=a[i]) then logick:=true else logick:=false;
                     end;
if (logick=true) then writeln('Число есть в массиве') else writeln('Числа нет в массиве');
end.
Массив
[8,5,7,3,9,4,9,2,7,5]
Введите число: 1
Числа нет в массиве
0
CAPITAL OF ROCK!
 Аватар для JokeR.BY
1281 / 708 / 982
Регистрация: 03.03.2010
Сообщений: 2,286
11.01.2016, 15:17
Лучший ответ Сообщение было отмечено Памирыч как решение

Решение

Pascal
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
const
    Ans: Array[Boolean] Of String = ('Number is NOT present in array!', 'Number is present in array!');
var
    ar: Array[Byte] Of Integer;
    flag: Boolean;
    i, n: Byte;
    number: Integer;
begin
    Randomize();
    repeat
        Write('Input n (>0): ');
        ReadLn(n);
    until (n > 0);
    WriteLn; Write('Original array: ');
    for i := 0 to n - 1 do
    begin
        ar[i] := Random(199) - 99;
        Write(ar[i]:4);
    end;
    WriteLn; i := 0;
    Write('Input number to search: '); ReadLn(number);
    repeat
        flag := (ar[i] = number);
        Inc(i);
    until ((flag) Or (i >= n));
    Write(Ans[flag]);
end.
0
2022 / 1621 / 489
Регистрация: 31.05.2009
Сообщений: 3,005
11.01.2016, 19:09
Pascal
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
const N = 10;
 
var x, i: Integer;
    a   : array [1..N+1] of Integer;
 
begin
  Randomize;
  for i := 1 to N do begin
    a[i] := Random(100) - 50;
    Write(' ', a[i])
  end;
  WriteLn;
  Write('Пренадлежит ли массиву значение: ');
  ReadLn(x);
  a[N+1] := x;
  i := 1;
  while a[i] <> x do Inc(i);
  if i > N then WriteLn('Нет.') else WriteLn('Да.')
end.
0
2923 / 844 / 324
Регистрация: 30.04.2009
Сообщений: 2,633
11.01.2016, 20:42
TonyWinter, в вашей программе если ввести значение не последнего элемента программа все равно выдаст что такого нет даже если таких будет 9 из 10
0
5 / 5 / 10
Регистрация: 08.01.2016
Сообщений: 80
11.01.2016, 21:11
mamedovvms, спасибо огромное, это же надо так облажаться.... =_\\
Вроде бы исправил. Теперь работает так, как я и хотел.
________________________________________ ________________
Pascal
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
const n=10;
begin
randomize;
var logick:array [1..n]of boolean;
var a:array [1..n] of integer;
var k:byte;
for var i:=1 to n do a[i]:=random(10);
println('Массив');
writeln(a);
 
var c:=readInteger('Введите число: ');
for var i:=1 to n do if (c=a[i]) then logick[i]:=true else logick[i]:=false;
for var i:=1 to n do if (logick[i]=true) then inc(k);
 
if (k>0) then println('Число в массиве есть') else println('Числа в массиве нет');
if (k>0) then writeln('Число встречается ',k,' раз(а)');
 
end.
Массив
[8,5,1,4,9,6,2,8,1,7]
Введите число: 7
Число в массиве есть
Число встречается 1 раз(а)
Массив
[7,9,5,2,6,3,6,1,1,5]
Введите число: 0
Числа в массиве нет
Массив
[6,0,5,0,6,3,4,7,5,6]
Введите число: 0
Число в массиве есть
Число встречается 2 раз(а)
0
Модератор
Эксперт Pascal/DelphiЭксперт NIX
 Аватар для bormant
7816 / 4635 / 2837
Регистрация: 22.11.2013
Сообщений: 13,158
Записей в блоге: 1
11.01.2016, 21:31
JokeR.BY,
n = 255, искомое число 255-е. Ошибка?
0
2923 / 844 / 324
Регистрация: 30.04.2009
Сообщений: 2,633
11.01.2016, 21:57
TonyWinter, можно просто сделать так
Pascal
1
2
3
4
5
6
flag:=false;
for i:=1 to n do 
 if a[i]=c then flag:=true;
 
if flag then writeln('yes')
else writeln('no');
но такой способ не совсем соответствует условию задачи, нам нужно просто узнать есть ли число в массиве, а это значит что если такое число стоит в массиве первым, тогда нет смысла проверять остальные элементы массива, по этому лучше использовать циклы while или repeat выход из которых происходит если i>n или flag=true

Добавлено через 3 минуты
Цитата Сообщение от bormant Посмотреть сообщение
n = 255, искомое число 255-е. Ошибка?
не совсем понятен ваш вопрос. Как связаны размерность массива и значение элемента массива????
0
5 / 5 / 10
Регистрация: 08.01.2016
Сообщений: 80
11.01.2016, 21:58
mamedovvms, а ведь была такая идея с флагом .=. спасибо за разъяснения
0
2923 / 844 / 324
Регистрация: 30.04.2009
Сообщений: 2,633
11.01.2016, 22:06
TonyWinter, Кстати можно использовать и цикл for но тогда и прерывание цикла break; то есть получится что то вот такое
Pascal
1
2
3
4
5
6
7
8
for i:=1 to n do 
 if a[i] = c then
  begin
   flag:=true;
   break;
  end;
if flag then writeln('yes')
else writeln('no');
или вот так
Pascal
1
2
3
4
5
for i:=1 to n do 
 if a[i] = c then
   break;
if a[i] = c then writeln('yes')
else writeln('no');
0
5 / 5 / 10
Регистрация: 08.01.2016
Сообщений: 80
11.01.2016, 22:23
mamedovvms, досрочные выходы из циклов я стараюсь избегать Лучше тогда циклы с условиями использовать
0
Модератор
Эксперт Pascal/DelphiЭксперт NIX
 Аватар для bormant
7816 / 4635 / 2837
Регистрация: 22.11.2013
Сообщений: 13,158
Записей в блоге: 1
11.01.2016, 22:27
mamedovvms,
посмотрите код в сообщении #3, увидели ошибку?
0
CAPITAL OF ROCK!
 Аватар для JokeR.BY
1281 / 708 / 982
Регистрация: 03.03.2010
Сообщений: 2,286
11.01.2016, 23:12
bormant, с чего вдруг?
0
CAPITAL OF ROCK!
 Аватар для JokeR.BY
1281 / 708 / 982
Регистрация: 03.03.2010
Сообщений: 2,286
11.01.2016, 23:20
вроде как всё гут отрабатывает о_О
Миниатюры
Как проверить принадлежит ли число массиву?  
0
Модератор
Эксперт Pascal/DelphiЭксперт NIX
 Аватар для bormant
7816 / 4635 / 2837
Регистрация: 22.11.2013
Сообщений: 13,158
Записей в блоге: 1
11.01.2016, 23:27
JokeR.BY,
хм, действительно ошибся, прошу прощения.

Привык писать без отдельной переменной-флага, а там случай полного диапазона типа нужно специально (несложно) предусматривать, например:
Pascal
1
2
i:=n; Inc(i); repeat Dec(i) until (a[i]=number) or (i=0);
WriteLn(Ans[a[i]=number]);
0
CAPITAL OF ROCK!
 Аватар для JokeR.BY
1281 / 708 / 982
Регистрация: 03.03.2010
Сообщений: 2,286
11.01.2016, 23:39
bormant, именно поэтому предпочитаю: если repeat - то вкупе с флагом, иначе - for (while) с брейком)
0
Модератор
Эксперт Pascal/DelphiЭксперт NIX
 Аватар для bormant
7816 / 4635 / 2837
Регистрация: 22.11.2013
Сообщений: 13,158
Записей в блоге: 1
12.01.2016, 00:12
JokeR.BY,
вообще оно на for ложилось бы идеально, если б не указание в описании языка на то, что в случае завершения цикла по Break переменная счетчика цикла определена, а при нормальном завершении -- не определена.
А поскольку гарантировать наличие искомого мы не можем, то и использовать цикл for по-простому без флага, как в примере выше, нельзя, только вроде такого:
Pascal
1
2
3
4
5
6
found:=False;
for j:=1 to n do
  if a[j]=num then begin
    found:=True; Break;
  end;
if found then { тут можно использовать значение j в качестве индекса }
а вариант, который просится, с точки зрения описания языка является неверным:
Pascal
1
2
3
for j:=1 to n do
  if a[j]=num then Break;
if a[j]=num then { нашли }
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
12.01.2016, 00:12
Помогаю со студенческими работами здесь

Определить,принадлежит ли заданный элемент массиву,используя рекурсии
помогите написать программку плиз)))

Определить,принадлежит ли заданный элемент данному одномерному массиву,используя рекурсию.
Определить,принадлежит ли заданный элемент данному одномерному массиву,используя рекурсию.

Как проверить принадлежит ли элемент множеству?
Всем привет) Писал програмку, столкнулся с проблемой: для того, что бы проверить принадлежит ли елемент множеству мы используем оператор...

Определить, принадлежит ли введенное число заданному массиву
Подскажите пожалуйста, у меня такое задание, есть массив, пользователь вводит с клавиатуры число и нужно определить , принадлежит ли это...

Методом деления пополам определить принадлежит ли число одномерному массиву.
Дан упорядоченный по возрастанию одномерный массив целых чисел. С клавиатуры вводится некоторое число. Методом деления пополам определить...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
17
Ответ Создать тему
Новые блоги и статьи
Символьное дифференцирование
igorrr37 13.02.2026
/ * Программа принимает математическое выражение в виде строки и выдаёт его производную в виде строки и вычисляет значение производной при заданном х Логарифм записывается как: (x-2)log(x^2+2) -. . .
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
И ясному Солнцу
zbw 12.02.2026
И ясному Солнцу, и светлой Луне. В мире покоя нет и люди не могут жить в тишине. А жить им немного лет.
«Знание-Сила»
zbw 12.02.2026
«Знание-Сила» «Время-Деньги» «Деньги -Пуля»
SDL3 для Web (WebAssembly): Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 12.02.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами и вызывать обработчики событий столкновения. . . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 11.02.2026
Содержание блога Библиотека SDL3 содержит встроенные инструменты для базовой работы с изображениями - без использования библиотеки SDL3_image. Пошагово создадим проект для загрузки изображения. . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL3_image
8Observer8 10.02.2026
Содержание блога Библиотека SDL3_image содержит инструменты для расширенной работы с изображениями. Пошагово создадим проект для загрузки изображения формата PNG с альфа-каналом (с прозрачным. . .
Установка Qt-версии Lazarus IDE в Debian Trixie Xfce
volvo 10.02.2026
В общем, достали меня глюки IDE Лазаруса, собранной с использованием набора виджетов Gtk2 (конкретно: если набирать текст в редакторе и вызвать подсказку через Ctrl+Space, то после закрытия окошка. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru