|
0 / 0 / 0
Регистрация: 13.12.2016
Сообщений: 3
|
|
Количество десятичных цифр числа n19.12.2016, 20:45. Показов 3014. Ответов 5
Метки цифры числа (Все метки)
Требуется решить две задачи с использованием рекурсии, но без &optional, initial element, т.к я не понимаю принципа их работы.
Дано натуральное число N. Определить функцию, зависящую от N, которая находит количество цифр числа N.
0
|
|
| 19.12.2016, 20:45 | |
|
Ответы с готовыми решениями:
5
Функция определяющая количество четных десятичных цифр числа |
|
188 / 155 / 17
Регистрация: 18.12.2015
Сообщений: 179
|
||||||||||||||||
| 19.12.2016, 23:53 | ||||||||||||||||
Сообщение было отмечено Catstail как решение
Решение
Рекурсивное решение:
В ряде случаев предпочитают решать через использование "аккумулятора" - специальной переменной, в которой "накапливают" ("аккумулируют") значение.
В конце n станет равным нулю, а acc станет равным количеству цифр в исходном числе. Если проследить вызовы, это выглядит так: (cifr 1234) (cifr-acc 1234 0) (cifr-acc 123 1) (cifr-acc 12 2) (cifr-acc 1 3) (cifr 0 4) 4 Если захотите узнать подробней - погуглите термины "инвариант цикла", "хвостовая рекурсия". В этом решении есть небольшое неудобство - приходится писать две функции вместо одной. Но, можно немного сжульничать и применить "&optional".
Теперь, если я вызову "(cifr 1234)", лисп увидит, что я не указал значение переменной acc и подставит значение по умолчанию, и последовательность вызовов будет выглядеть так: (cifr 1234 0) (cifr 123 1) (cifr 12 2) (cifr 1 3) (cifr 0 4) Аванес, сначала освойте рекурсию, потом разберитесь с использованием накапливаемого значения ("аккумуляторов"). А в самом "&optional" сложностей нет никаких.
3
|
||||||||||||||||
|
188 / 155 / 17
Регистрация: 18.12.2015
Сообщений: 179
|
||||||||||||||||
| 20.12.2016, 18:26 | ||||||||||||||||
|
Ноль не всегда считают натуральным числом. Исходя из этого, я доопределил в нуле функцию так, чтоб код был возможно проще.
Но, судя по всему, в задаче подразумевалось, что 0 считаем натуральным числом, и для него функция должна выдавать результат: 1 цифра. Вот исправленные версии кода:
3
|
||||||||||||||||
|
4710 / 4405 / 380
Регистрация: 12.05.2012
Сообщений: 3,102
|
||||||
| 21.12.2016, 09:23 | ||||||
|
вариант:
2
|
||||||
| 21.12.2016, 09:23 | |
|
Помогаю со студенческими работами здесь
6
Сформировать массив десятичных цифр числа А. Элементы массива цифр сдвинуть циклически влево на 1 позицию Выделение десятичных цифр числа Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
Новые блоги и статьи
|
|||
|
Модель заражения группы наркоманов
alhaos 17.04.2026
Условия задачи сформулированы тут
Суть:
- Группа наркоманов из 10 человек.
- Только один инфицирован ВИЧ.
- Колются одной иглой.
- Колются раз в день.
- Колются последовательно через. . .
|
Мысли в слух. Про "навсегда".
kumehtar 16.04.2026
Подумалось тут, что наверное очень глупо использовать во всяких своих установках понятие "навсегда". Это очень сильное понятие, и я только начинаю понимать край его смысла, не смотря на то что давно. . .
|
My Business CRM
MaGz GoLd 16.04.2026
Всем привет, недавно возникла потребность создать CRM, для личных нужд. Собственно программа предоставляет из себя базу данных клиентов, в которой можно фиксировать звонки, стадии сделки, а также. . .
|
Знаешь почему 90% людей редко бывают счастливыми?
kumehtar 14.04.2026
Потому что они ждут. Ждут выходных, ждут отпуска, ждут удачного момента. . .
а удачный момент так и не приходит.
|
|
Фиксация колонок в отчете СКД
Maks 14.04.2026
Фиксация колонок в СКД отчета типа Таблица.
Задача: зафиксировать три левых колонки в отчете.
Процедура ПриКомпоновкеРезультата(ДокументРезультат, ДанныеРасшифровки, СтандартнаяОбработка)
/ / . . .
|
Настройки VS Code
Loafer 13.04.2026
{
"cmake. configureOnOpen": false,
"diffEditor. ignoreTrimWhitespace": true,
"editor. guides. bracketPairs": "active",
"extensions. ignoreRecommendations": true,
. . .
|
Оптимизация кода на разграничение прав доступа к элементам формы
Maks 13.04.2026
Алгоритм из решения ниже реализован на нетиповом документе, разработанного в конфигурации КА2.
Задачи, как таковой, поставлено не было, проделанное ниже исключительно моя инициатива.
Было так:. . .
|
Контроль заполнения и очистка дат в зависимости от значения перечислений
Maks 12.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеПерсонала", разработанного в конфигурации КА2.
Задача: реализовать контроль корректности заполнения дат назначения. . .
|