Форум программистов, компьютерный форум, киберфорум
PascalABC.NET
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.65/40: Рейтинг темы: голосов - 40, средняя оценка - 4.65
тыдыщ
 Аватар для klast
206 / 189 / 166
Регистрация: 19.01.2011
Сообщений: 483

Проверка наличия элемента во множестве

28.08.2012, 00:32. Показов 8478. Ответов 12
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
в Питоне есть такая штука как множества, и там, например, поиск во множестве элемента составляет O(1), что очень удобно
есть ли что-нить похожее в паскале?
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
28.08.2012, 00:32
Ответы с готовыми решениями:

Проверка на наличие определённого элемента в множестве
Написал модуль, функции выполняют заполнение множеств(mna и mnb), объединение(объединённые множества mna и mnb "превращаются" в...

Проверка наличия элемента в layout
Доброго времени суток. Подскажите - как провести проверку наличия элемента в коде. В моем случае необходимо провести проверку наличия...

Проверка наличия элемента в списке
Пусть имеется такой список public class Luck { public int ID { get; set; } public string Name...

12
 Аватар для Darius
37 / 37 / 26
Регистрация: 31.05.2009
Сообщений: 103
28.08.2012, 05:15
Есть тип "Множество"

Pascal
1
2
3
4
5
6
7
8
9
10
11
12
13
var
  a: set of '0'..'9';
 
begin
  a += ['1', '3', '5', '7', '9'];
  writeln(a);
  if '1' in a then 
    writeln('true');
    
  foreach s: char in a do
    write(s, ' ');
  
end.
1
тыдыщ
 Аватар для klast
206 / 189 / 166
Регистрация: 19.01.2011
Сообщений: 483
28.08.2012, 12:17  [ТС]
а за какое время он добавляет во множество и за какое время он ищет элемент там?
0
Супер-модератор
Эксперт Pascal/DelphiАвтор FAQ
 Аватар для volvo
33398 / 21508 / 8236
Регистрация: 22.10.2011
Сообщений: 36,906
Записей в блоге: 12
28.08.2012, 12:37
Работа со множествами - битовая операция. Все сводится к проверке определенного бита, поэтому O(1).
1
 Аватар для Darius
37 / 37 / 26
Регистрация: 31.05.2009
Сообщений: 103
28.08.2012, 13:02
klast, Берешь к примеру set of integer, добавляешь 100000 элементов. Считаешь по таймеру за сколько времени выполнится, полученный результат делишь на 100000, вот тебе и время добавления одного элемента. То же самое можешь проделать и с поиском.

Простейший пример подсчета времени операции, но скорее всего увидишь одни нули, или пару милисекунд
1
тыдыщ
 Аватар для klast
206 / 189 / 166
Регистрация: 19.01.2011
Сообщений: 483
28.08.2012, 13:32  [ТС]
Цитата Сообщение от UI Посмотреть сообщение
Работа со множествами - битовая операция. Все сводится к проверке определенного бита, поэтому O(1).
добавление во множество, происходит на O(N)
надо в памяти создать новое место для элемента, а это происходит на O(N)
0
Супер-модератор
Эксперт Pascal/DelphiАвтор FAQ
 Аватар для volvo
33398 / 21508 / 8236
Регистрация: 22.10.2011
Сообщений: 36,906
Записей в блоге: 12
28.08.2012, 13:41
Это ты про питон рассказываешь? Может быть. В Паскале, когда ты описываешь тип множества, уже известно, сколько бит (и, соответственно, байт) надо для его представления, и в памяти под переменную выделяется нужное количество байт. Еще раз: это битовая операция. Добавление элемента во множество - это просто включение определенного бита. Выполняется за O(1).

(хотя, в Pascal ABC.NET может быть другая история, там от Паскаля-то ничего не осталось, только ключевые слова некоторые. Возможно, они и множества по-своему реализовали)
1
Почетный модератор
 Аватар для Puporev
64315 / 47611 / 32743
Регистрация: 18.05.2008
Сообщений: 115,167
28.08.2012, 14:24
В Pascal ABC.NET можно запустить почти любую простенькую программу, написанную в Турбо Паскале или в простом АВС.
0
тыдыщ
 Аватар для klast
206 / 189 / 166
Регистрация: 19.01.2011
Сообщений: 483
28.08.2012, 14:31  [ТС]
Еще один вопрос!
эти множества есть только в ПаскальАБЦ.НЕТ?
0
Почетный модератор
 Аватар для Puporev
64315 / 47611 / 32743
Регистрация: 18.05.2008
Сообщений: 115,167
28.08.2012, 14:33
klast, В любом Паскале и Делфи, другое не знаю.
1
 Аватар для Darius
37 / 37 / 26
Регистрация: 31.05.2009
Сообщений: 103
28.08.2012, 14:33
TurboPascal PascalABC точно есть, на счет борланда не в курсе, не работал с ним, но думаю тоже есть
1
тыдыщ
 Аватар для klast
206 / 189 / 166
Регистрация: 19.01.2011
Сообщений: 483
28.08.2012, 14:44  [ТС]
хмм, у меня код работает на абц.нет, а на обычном не хочет

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
var
  s: string;
  i, j, res, n, l: longint;
  h: boolean;
  used: set of string;
 
begin
  readln(s);
  res := 0;
  n := length(s);
  for i := 1 to n do
    for j := i to n do
      for l := j to n do
        if (i <> j) and (j <> l) and (l <> i) then
        begin
          h := true;
          if s[i] + s[j] + s[l] in used then h := false;
          if (h) and (s[i] <> '0') then 
          begin
            inc(res);
            used :=  used + [s[i] + s[j] + s[l]];
          end;
        end;
  writeln(res);
end.
чо в нем не так?
0
Почетный модератор
 Аватар для Puporev
64315 / 47611 / 32743
Регистрация: 18.05.2008
Сообщений: 115,167
28.08.2012, 14:51
klast, В простом нет множества строк, только set of byte и set of char, а также множества на основе перечислимого типа.
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
28.08.2012, 14:51
Помогаю со студенческими работами здесь

JSON, проверка наличия элемента
Доброго дня, уважаемые. Буду благодарен за помощь в этом вопросе. Вот часть парсинга JSON: for i := 0 to JsonArray.Size - 1 do ...

Проверка наличия элемента в Webbrowser
Как проверить есть ли элемент в Webbrowser? есть есть то showmessage('1'); Если нету то showmessage('2'); Пробую так: procedure...

Проверка наличия элемента (библиотека jsoup)
Всем привет! Подскажите, как можно сделать проверку на наличие элемента? То бишь есть у меня, скажем, некий Document doc, в котором я...

Проверка наличия элемента на странице циклом и остановка в случае true
Доброго дня уважаемое сообщество. Возник очень неприятный вопрос. У нас есть скрипт который подгружает некий блок через некое время...

Проверка наличия элемента в массиве методом половинного деления (бинарный, бисекция)
Задан массив. С клавиатуры вводится значение и нужно проверить методом половинного деления есть ли такой элемент в массиве. Сортирую его...


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

Или воспользуйтесь поиском по форуму:
13
Ответ Создать тему
Новые блоги и статьи
Модульный подход на примере F#
DevAlt 06.03.2026
В блоге дяди Боба наткнулся на такое определение: В этой книге («Подход, основанный на вариантах использования») Ивар утверждает, что архитектура программного обеспечения — это структуры,. . .
Управление камерой с помощью скрипта OrbitControls.js на Three.js: Вращение, зум и панорамирование
8Observer8 05.03.2026
Содержание блога Финальная демка в браузере работает на Desktop и мобильных браузерах. Итоговый код: orbit-controls-threejs-js. zip. Сканируйте QR-код на мобильном. Вращайте камеру одним пальцем,. . .
SDL3 для Web (WebAssembly): Синхронизация спрайтов SDL3 и тел Box2D
8Observer8 04.03.2026
Содержание блога Финальная демка в браузере. Итоговый код: finish-sync-physics-sprites-sdl3-c. zip На первой гифке отладочные линии отключены, а на второй включены:. . .
SDL3 для Web (WebAssembly): Идентификация объектов на Box2D v3 - использование userData и событий коллизий
8Observer8 02.03.2026
Содержание блога Финальная демка в браузере. Итоговый код: finish-collision-events-sdl3-c. zip Сканируйте QR-код на мобильном и вы увидите, что появится джойстик для управления главным героем. . . .
Реалии
Hrethgir 01.03.2026
Нет, я не закончил до сих пор симулятор. Эта задача сложнее. Не получилось уйти в плавсостав, но оно и к лучшему, возможно. Точнее получалось - но сварщиком в палубную команду, а это значит, в моём. . .
Ритм жизни
kumehtar 27.02.2026
Иногда приходится жить в ритме, где дел становится всё больше, а вовлечения в происходящее — всё меньше. Плотный график не даёт вниманию закрепиться ни на одном событии. Утро начинается с быстрых,. . .
SDL3 для Web (WebAssembly): Сборка библиотек: SDL3, Box2D, FreeType, SDL3_ttf, SDL3_mixer и SDL3_image из исходников с помощью CMake и Emscripten
8Observer8 27.02.2026
Недавно вышла версия 3. 4. 2 библиотеки SDL3. На странице официальной релиза доступны исходники, готовые DLL (для x86, x64, arm64), а также библиотеки для разработки под Android, MinGW и Visual Studio. . . .
SDL3 для Web (WebAssembly): Реализация движения на Box2D v3 - трение и коллизии с повёрнутыми стенами
8Observer8 20.02.2026
Содержание блога Box2D позволяет легко создать главного героя, который не проходит сквозь стены и перемещается с заданным трением о препятствия, которые можно располагать под углом, как верхнее. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru