|
1505 / 969 / 812
Регистрация: 30.04.2016
Сообщений: 3,337
|
|||||||||||
Найти количество N-значных чисел, состоящих из цифр 1 и 2, не содержащих три подряд идущих одинаковых цифры08.05.2017, 23:05. Показов 7659. Ответов 15
Метки нет (Все метки)
Здравствуйте! Вот еще одна задача с E-olymp (№ 12). К сожалению, только 67% (один - неправильный ответ, остальные не прошли по времени). Мне пока, хотя бы, выяснить где неправильный ответ
Для решения использовал проверенные функции. А вот моя (IfThree (string s)) - возможно, далеко не идеальна. Прошу Вашей помощи.Числа Дикари, живущие на острове невезения умеют считать только до двух. Поэтому у них есть только две цифры — цифра 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
Дан текст, содержащий цифры. Найти наибольшее количество идущих подряд цифр Найти, сколько шестизначных чисел в четверичной системе не содержат двух одинаковых цифр, идущих подряд? |
|
21 / 21 / 10
Регистрация: 11.09.2015
Сообщений: 103
|
|
| 09.05.2017, 00:00 | |
|
Fixer_84, может регулярные выражения сработают?
0
|
|
|
1505 / 969 / 812
Регистрация: 30.04.2016
Сообщений: 3,337
|
|
| 09.05.2017, 00:04 [ТС] | |
|
Kudryashov_R_D, здравствуйте! Может быть, не пробовал. Тут эта функция на каждом шаге проверяет. Будет ли это быстрее. Попробую.
Добавлено через 2 минуты Ромаха, здравствуйте! Да, я думал, что размещения с повторениями сработают. Раньше меня эта рекурсия выручала. В этот раз все сложнее. Вы правы, скорее всего, придется менять алгоритм. Может как-то попробовать через двузначные числа...Там вместо 1 и 2 будет 0 и 1. Но с ними тоже не работал. Не знаю.
0
|
|
|
21 / 21 / 10
Регистрация: 11.09.2015
Сообщений: 103
|
|
| 09.05.2017, 00:24 | |
|
Или попробуй сравнивать substr (s, i+1, 2) == "11" или substr (s, i+1, 2) == "22", если s[i] = '1' или '2'
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, 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 | ||
https://oeis.org/search?q=2%2C... 1%81%D0%BA
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 цифры - нечётные? Подсчитать количество одинаковых чисел массива, идущих подряд
Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
Новые блоги и статьи
|
|||
|
SDL3 для Web (WebAssembly): Обработчик клика мыши в браузере ПК и касания экрана в браузере на мобильном устройстве
8Observer8 02.02.2026
Содержание блога
Для начала пошагово создадим рабочий пример для подготовки к экспериментам в браузере ПК и в браузере мобильного устройства. Потом напишем обработчик клика мыши и обработчик. . .
|
Философия технологии
iceja 01.02.2026
На мой взгляд у человека в технических проектах остается роль генерального директора. Все остальное нейронки делают уже лучше человека. Они не могут нести предпринимательские риски, не могут. . .
|
SDL3 для Web (WebAssembly): Вывод текста со шрифтом TTF с помощью SDL3_ttf
8Observer8 01.02.2026
Содержание блога
В этой пошаговой инструкции создадим с нуля веб-приложение, которое выводит текст в окне браузера. Запустим на Android на локальном сервере. Загрузим Release на бесплатный. . .
|
SDL3 для Web (WebAssembly): Сборка C/C++ проекта из консоли
8Observer8 30.01.2026
Содержание блога
Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
|
|
SDL3 для Web (WebAssembly): Установка Emscripten SDK (emsdk) и CMake для сборки C и C++ приложений в Wasm
8Observer8 30.01.2026
Содержание блога
Для того чтобы скачать Emscripten SDK (emsdk) необходимо сначало скачать и уставить Git: Install for Windows. Следуйте стандартной процедуре установки Git через установщик. . . .
|
SDL3 для Android: Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 29.01.2026
Содержание блога
Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами. Версия v3 была полностью переписана на Си, в. . .
|
Инструменты COM: Сохранение данный из VARIANT в файл и загрузка из файла в VARIANT
bedvit 28.01.2026
Сохранение базовых типов COM и массивов (одномерных или двухмерных) любой вложенности (деревья) в файл, с возможностью выбора алгоритмов сжатия и шифрования.
Часть библиотеки BedvitCOM
Использованы. . .
|
SDL3 для Android: Загрузка PNG с альфа-каналом с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 28.01.2026
Содержание блога
SDL3 имеет собственные средства для загрузки и отображения PNG-файлов с альфа-каналом и базовой работы с ними. В этой инструкции используется функция SDL_LoadPNG(), которая. . .
|