Модераторы: Poseidon
  

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> [Алгоритм] Наименьшее натуральное число, не входящее в последовательность. 
:(
    Опции темы
fsherstobitov
Дата 19.6.2010, 08:09 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 7
Регистрация: 12.9.2008

Репутация: нет
Всего: нет



Дан массив натуральных чисел. Необходимо найти наименьшее натурально число, не входящее в данный массив. Алгоритм должен выполняться за О(n).
PM MAIL   Вверх
Фантом
Дата 19.6.2010, 14:15 (ссылка) |    (голосов:1) Загрузка ... Загрузка ... Быстрая цитата Цитата


Вы это прекратите!
***


Профиль
Группа: Участник Клуба
Сообщений: 1516
Регистрация: 23.3.2008

Репутация: 7
Всего: 49



Заводим массив 1:n из булевских переменных B, весь забитый, например, false. Проходимся один раз по исходному массиву, для каждого элемента со значением q устанавливая в булевском массиве элемент B[q] в true (если q>n, то ничего не делаем).
Затем проходимся по булевскому массиву и ищем номер первого элемента, имеющего значение false. Это и есть ответ.
PM   Вверх
bems
Дата 19.6.2010, 19:40 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
****


Профиль
Группа: Комодератор
Сообщений: 3400
Регистрация: 5.1.2006

Репутация: 0
Всего: 88



Фантом, это О(2n). Нет?

Это сообщение отредактировал(а) bems - 19.6.2010, 19:47


--------------------
Обижено школьников: 8
PM MAIL   Вверх
Фантом
Дата 19.6.2010, 20:02 (ссылка) |    (голосов:1) Загрузка ... Загрузка ... Быстрая цитата Цитата


Вы это прекратите!
***


Профиль
Группа: Участник Клуба
Сообщений: 1516
Регистрация: 23.3.2008

Репутация: 7
Всего: 49



Цитата(bems @  19.6.2010,  19:40 Найти цитируемый пост)
это О(2n). Нет?

И нет, и да.  smile  Смысл O-символики при оценке сложности алгоритма (во всех других случаях, впрочем, тоже) в том, что если количество операций алгоритма зависит от n как f(n), то сложность алгоритма O(g(n)) должна быть такой, чтобы предел f(n)/g(n) при n, стремящемся к бесконечности, оказался ненулевым и конечным.

Как следствие, O(n) и O(2*n) попросту ничем не отличаются (и второй вариант при описании асимптотической сложности алгоритмов не используется). Это, кстати, логично не только с формальной точки зрения: поскольку мы не знаем точно, какое количество тактов процессора будет использовано для выполнения той или иной операции, то сравнивать линейные по n алгоритмы по коэффициенту малоосмысленно - вполне возможно, что какой-либо "однопроходный" алгоритм за счет большей трудоемкости обработки одной ячейки массива будет выполняться дольше, чем мой "двупроходный". 

Другое дело, что бывают случаи, когда для алгоритма, например, с O(n^3) для некоторого диапазона n на некоторой определенной архитектуре можно получить более быструю реализацию, чем для другого алгоритма с O(n^2), но это уже совсем другая задача, для которой нужно конкретизировать и "стоимость" элементарных операций, и максимальные n, для которых нужно найти эффективное решение.
PM   Вверх
bems
Дата 19.6.2010, 21:25 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
****


Профиль
Группа: Комодератор
Сообщений: 3400
Регистрация: 5.1.2006

Репутация: 0
Всего: 88



К стати в большинстве случаев подойдет найти минимум массива и отнять единицу. Есть мысли как адаптировать это чтоб работало всегда?


--------------------
Обижено школьников: 8
PM MAIL   Вверх
Фантом
Дата 19.6.2010, 21:31 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Вы это прекратите!
***


Профиль
Группа: Участник Клуба
Сообщений: 1516
Регистрация: 23.3.2008

Репутация: 7
Всего: 49



Цитата(bems @  19.6.2010,  21:25 Найти цитируемый пост)
К стати в большинстве случаев подойдет найти минимум массива и отнять единицу.

Нет, не годится. Допустим, массив заполнен числами 10,11,12,13 и т.д. Ответ должен равняться 1, а не 9.

Собственно говоря, тут возможны только два варианта - либо минимум не равен 1, и тогда ответ - единица. Либо минимум равен 1 и это не дает вообще никакой информации об ответе.
PM   Вверх
bems
Дата 19.6.2010, 21:34 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
****


Профиль
Группа: Комодератор
Сообщений: 3400
Регистрация: 5.1.2006

Репутация: 0
Всего: 88



Цитата(Фантом @  19.6.2010,  21:31 Найти цитируемый пост)
Нет, не годится. Допустим, массив заполнен числами 10,11,12,13 и т.д. Ответ должен равняться 1, а не 9.
Я дичайше затупил.




--------------------
Обижено школьников: 8
PM MAIL   Вверх
fsherstobitov
Дата 20.6.2010, 21:13 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 7
Регистрация: 12.9.2008

Репутация: нет
Всего: нет



Цитата(Фантом @ 19.6.2010,  14:15)
Заводим массив 1:n из булевских переменных B, весь забитый, например, false. Проходимся один раз по исходному массиву, для каждого элемента со значением q устанавливая в булевском массиве элемент B[q] в true (если q>n, то ничего не делаем).
Затем проходимся по булевскому массиву и ищем номер первого элемента, имеющего значение false. Это и есть ответ.

Спасибо за ответ!
PM MAIL   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
Правила форума "Центр помощи"

ВНИМАНИЕ! Прежде чем создавать темы, или писать сообщения в данный раздел, ознакомьтесь, пожалуйста, с Правилами форума и конкретно этого раздела.
Несоблюдение правил может повлечь за собой самые строгие меры от закрытия/удаления темы до бана пользователя!


  • Название темы должно отражать её суть! (Не следует добавлять туда слова "помогите", "срочно" и т.п.)
  • При создании темы, первым делом в квадратных скобках укажите область, из которой исходит вопрос (язык, дисциплина, диплом). Пример: [C++].
  • В названии темы не нужно указывать происхождение задачи (например "школьная задача", "задача из учебника" и т.п.), не нужно указывать ее сложность ("простая задача", "легкий вопрос" и т.п.). Все это можно писать в тексте самой задачи.
  • Если Вы ошиблись при вводе названия темы, отправьте письмо любому из модераторов раздела (через личные сообщения или report).
  • Для подсветки кода пользуйтесь тегами [code][/code] (выделяйте код и нажимаете на кнопку "Код"). Не забывайте выбирать при этом соответствующий язык.
  • Помните: один топик - один вопрос!
  • В данном разделе запрещено поднимать темы, т.е. при отсутствии ответов на Ваш вопрос добавлять новые ответы к теме, тем самым поднимая тему на верх списка.
  • Если вы хотите, чтобы вашу проблему решили при помощи определенного алгоритма, то не забудьте описать его!
  • Если вопрос решён, то воспользуйтесь ссылкой "Пометить как решённый", которая находится под кнопками создания темы или специальным флажком при ответе.

Более подробно с правилами данного раздела Вы можете ознакомится в этой теме.

Если Вам помогли и атмосфера форума Вам понравилась, то заходите к нам чаще! С уважением, Poseidon, Rodman

 
1 Пользователей читают эту тему (1 Гостей и 0 Скрытых Пользователей)
0 Пользователей:
« Предыдущая тема | Центр помощи | Следующая тема »


 




[ Время генерации скрипта: 0.1140 ]   [ Использовано запросов: 21 ]   [ GZIP включён ]


Реклама на сайте     Информационное спонсорство

 
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности     Powered by Invision Power Board(R) 1.3 © 2003  IPS, Inc.