![]() 1505 / 969 / 812
Регистрация: 30.04.2016
Сообщений: 3,337
|
|||||||||||
Найти количество N-значных чисел, состоящих из цифр 1 и 2, не содержащих три подряд идущих одинаковых цифры08.05.2017, 23:05. Показов 7249. Ответов 15
Метки нет Все метки)
(
Здравствуйте! Вот еще одна задача с E-olymp (№ 12). К сожалению, только 67% (один - неправильный ответ, остальные не прошли по времени). Мне пока, хотя бы, выяснить где неправильный ответ
![]() Числа Дикари, живущие на острове невезения умеют считать только до двух. Поэтому у них есть только две цифры — цифра 1 и цифра 2. Кроме того, дикари очень суеверные люди. Числа, в которых стоят подряд три одинаковые цифры, они считают несчастливыми и не используют. Например, число 1221212 можно использовать, так как в нем нет трех подряд идущих одинаковых цифр. А число 12121112 — нельзя. В нем есть три подряд идущие цифры (в этом примере это единицы). Ваша задача заключается в том, чтобы выяснить, сколько существует N-значных чисел, состоящих только из цифр 1 и 2 таких, что в них нет трех подряд идущих одинаковых цифр . Входные данные: Единственная строка входного файла содержит натуральное число N, 1 ≤ N ≤ 30. Выходные данные: Выведите в выходной файл количество N-значных чисел, состоящих из только из цифр 1 и 2, и не содержащих трех подряд идущих одинаковых цифр. Вывод числа должен осуществляться с переводом строки. Мое решение (для N <= 20 - работает, дальше зависает):
Где неправильный ответ - нашел. При N = 1, k = 2. Как можно оптимизировать это решение? Добавлено через 27 минут Все, кажется, сводится к тому, чтобы быстро проверить, содержит ли одна из комбинаций три подряд идущие 2 или 1. Я сделал это с помощью функции IsThree(). Можно как-то ее оптимизировать? Добавлено через 17 минут Сделал так, но лучше не стало. По-прежнему 9 тестов из 30 не проходят по времени. Кажется дело в основном алгоритме:
Может, наоборот, посчитать те, которые содержат 111 или 222 и вычесть их из общего количеcтва? Но будет ли так быстрее... Добавлено через 8 минут Может как-то применить алгоритм для двузначного числа...(0100101 - использовать вместо 1 и 2?) Как там поведут себя биты...Ума не приложу.
0
|
08.05.2017, 23:05 | |
Ответы с готовыми решениями:
15
Дан текст, содержащий цифры. Найти наибольшее количество идущих подряд цифр Найти, сколько шестизначных чисел в четверичной системе не содержат двух одинаковых цифр, идущих подряд? |
08.05.2017, 23:18 | |
Снова неправильный подход. Нужно дп.
0
|
![]() 1505 / 969 / 812
Регистрация: 30.04.2016
Сообщений: 3,337
|
|
09.05.2017, 00:04 [ТС] | |
Kudryashov_R_D, здравствуйте! Может быть, не пробовал. Тут эта функция на каждом шаге проверяет. Будет ли это быстрее. Попробую.
Добавлено через 2 минуты Ромаха, здравствуйте! Да, я думал, что размещения с повторениями сработают. Раньше меня эта рекурсия выручала. В этот раз все сложнее. Вы правы, скорее всего, придется менять алгоритм. Может как-то попробовать через двузначные числа...Там вместо 1 и 2 будет 0 и 1. Но с ними тоже не работал. Не знаю.
0
|
![]() 1505 / 969 / 812
Регистрация: 30.04.2016
Сообщений: 3,337
|
||||||
09.05.2017, 00:43 [ТС] | ||||||
Kudryashov_R_D, Сделал так. ничего не изменилось:
0
|
21 / 21 / 10
Регистрация: 11.09.2015
Сообщений: 103
|
||||||
09.05.2017, 02:49 | ||||||
А может делать проверку только одного очередного i-го символа и в зависимости от его значения передавать проверку следующего i+1 одной из функций, "знающих" о двух предшествующих символах: Prev11 (i), Prev22(i), Prev12(i), Prev21(i).
Добавлено через 36 минут Вместо 4 функций можно использовать switch (ij), где ij = 11, 22, 12 или 21. Добавлено через 1 час 16 минут Например Кликните здесь для просмотра всего текста
Добавлено через 11 минут Нет, этот код выдаёт лишние числа
0
|
09.05.2017, 03:11 | |||||||||||
А мы без ДП и прочих ужасов, с наивным однострочником:
![]()
1
|
21 / 21 / 10
Регистрация: 11.09.2015
Сообщений: 103
|
||||||
09.05.2017, 03:47 | ||||||
А вот так работает
Кликните здесь для просмотра всего текста
Добавлено через 20 минут Но это не задача с олимпиады!
1
|
09.05.2017, 13:38 | ||
Пишешь код в одну строку, называешь однострочником, ликуешь. - неплохой план Это и есть дп(ну как дп). Только без запоминания. А эт уже не очень
0
|
09.05.2017, 14:54 | |
Ну для обоснованного ликования надо чтобы кот при этом влезал в эту одну строчку экрана.
А ДП это будет когда (если) мемоизацию прикрутить. И в данном случае это более чем тривиально (банальный массив 30*2). Но и без него для n=30 неплохо получилось, особенно на фоне остального ужаса, написанного в теме - который и есть лол (в сравнении с).
0
|
![]() 1505 / 969 / 812
Регистрация: 30.04.2016
Сообщений: 3,337
|
|
09.05.2017, 15:33 [ТС] | |
Спасибо всем! А вообще, не имея решения _Ivana, я бы дальше действовал так: У меня программа считает для N <= 20. И я получаю вот такую последовательность: 2, 4, 6, 10, 16, 26, 42, 68, 110, 178, 288, 466, 754, 1220, 1974, 3194, 5168, 8362, 13530, 21892... Ее, возможно, можно расшифровать и сделать несложное решение. Вот этим сейчас и займусь
![]()
0
|
09.05.2017, 15:38 | ||
![]()
0
|
![]() 1505 / 969 / 812
Регистрация: 30.04.2016
Сообщений: 3,337
|
||||||
09.05.2017, 16:01 [ТС] | ||||||
Получается, что каждый последующий равен сумме двух предыдущих. Вот и все
![]() Добавлено через 17 минут Вот грубое и на скорую руку решение с использованием массивов (M = 30, можно больше). Довольно быстро работает!
0
|
21 / 21 / 10
Регистрация: 11.09.2015
Сообщений: 103
|
|
09.05.2017, 17:18 | |
Если решать "в лоб", то количество N-разрядных чисел из 0/1, не содержащих подряд 3-х нулей или единиц - Q(N), равно разности всех N-разрядных чисел 2^N минус удвоенное количество групп из 0 или 1 от 3 до N в группе, соседствующие либо с границей числа, либо с 1 или 0 (например, 3-х групп 0000,0001,1000 для N=4 и т.д.). Для N=3,4,5 искомое Q(N) легко вычислить на бумаге. И вариант N=6 тоже не труден. Если положиться на Q(N) = Q(N-1)+Q(N-2), то счёт элементарен. Хотя эта индукция не доказана.
Но откуда _Ivana взяла свою рекуррентную формулу - вот что мучает такого профана, как я! Ссылка на oeis.org/search?q= ... не много мне дала.
0
|
09.05.2017, 18:04 | |||||||
![]()
1
|
09.05.2017, 18:04 | |
Помогаю со студенческими работами здесь
16
Найти наибольшее количество цифр, идущих подряд. Исключить из массива все символы цифры Сколько среди 5-значных чисел таких, в которых подряд не менее 4 одинаковых цифр? Сколько существует 6-значных чисел, у которых нет одинаковых цифр, а 2 и 4 цифры - нечётные? Подсчитать количество одинаковых чисел массива, идущих подряд
Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
Опции темы | |
|
Новые блоги и статьи
![]() |
||||
Мульти-тенантные БД с PostgreSQL Row Security
Codd 23.04.2025
Современные облачные сервисы и бизнес-приложения всё чаще обслуживают множество клиентов в рамках единой программной инфраструктуры. Эта архитектурная модель, известная как мульти-тенантность, стала. . .
|
Реализация конвейеров машинного обучения с Python и Scikit-learn
AI_Generated 23.04.2025
Мир данных вокруг нас растёт с каждым днём, и умение эффективно обрабатывать информацию стало необходимым навыком. Специалисты по машинному обучению ежедневно сталкиваются с задачами предобработки. . .
|
Контроллеры Kubernetes Ingress: Сравнительный анализ
Mr. Docker 23.04.2025
В Kubernetes управление входящим трафиком представляет собой одну из ключевых задач при построении масштабируемых и отказоустойчивых приложений. Ingress — это API-объект, который служит вратами. . .
|
Оптимизация кода Python с Cython и Numba
py-thonny 23.04.2025
Python прочно обосновался в топе языков программирования благодаря своей простоте и гибкости. Разработчики любят его за читабельность кода и богатую экосистему библиотек. Но у этой медали есть и. . .
|
Микросервис на Python с FastAPI и Docker
ArchitectMsa 23.04.2025
В эпоху облачных вычислений и растущей сложности программных продуктов классическая монолитная архитектура всё чаще уступает место новым подходам. Микросервисная архитектура становится фаворитом. . .
|
Создаем веб-приложение на Vue.js и Laravel
Reangularity 23.04.2025
Выбор правильного технологического стека определяет успех веб-проекта. Laravel и Vue. js формируют отличную комбинацию для создания современных приложений. Laravel — это PHP-фреймворк с элегантным. . .
|
Максимальная производительность C#: Span<T> и Memory<T>
stackOverflow 22.04.2025
Мир высоконагруженных приложений безжалостен к неэффективному коду. Каждая миллисекунда на счету, каждый выделенный байт памяти может стать причиной падения производительности. Разработчики на C#. . .
|
JWT аутентификация в Java
Javaican 21.04.2025
JWT (JSON Web Token) представляет собой открытый стандарт (RFC 7519), который определяет компактный и самодостаточный способ передачи информации между сторонами в виде JSON-объекта. Эта информация. . .
|
Спринты Agile: Планирование, выполнение, ревью и ретроспектива
EggHead 21.04.2025
Спринты — сердцевина Agile-методологии, позволяющая командам создавать работающий продукт итерационно, с постоянной проверкой гипотез и адаптацией к изменениям. В основе концепции спринтов лежит. . .
|
Очередные открытия мега простых чисел, сделанные добровольцами с помощью домашних компьютеров
Programma_Boinc 21.04.2025
Очередные открытия мега простых чисел, сделанные добровольцами с помощью домашних компьютеров.
3 марта 2025 года, в результате обобщенного поиска простых чисел Ферма в PrimeGrid был найден. . .
|