За последние 24 часа нас посетили 17590 программистов и 1675 роботов. Сейчас ищут 1892 программиста ...

задачка на итеративный процесс

Тема в разделе "JavaScript и AJAX", создана пользователем Taktreba, 3 сен 2017.

  1. Taktreba

    Taktreba Активный пользователь

    С нами с:
    11 янв 2017
    Сообщения:
    543
    Симпатии:
    132
    Реализуйте тело функции smallestDivisor, используя итеративный процесс. Эта функция должна находить наименьший делитель заданного числа.

    Доп. условия: число, передаваемое в функцию, больше нуля; делитель должен быть больше единицы, за исключением случая, когда аргументом является единица (наименьшим делителем которой является также единица).

    Например, наименьший делитель числа 15 это 3.

    smallestDivisor(15); // 3
    smallestDivisor(17); // 17

    Идея алгоритма:

    1. Попробуйте разделить число на 2.
    2. Если число делится без остатка, то это наименьший делитель.
    3. Если нет, то попробуйте следующий делитель.
    4. Если ничего не делит число без остатка, то переданное число является простым, так что его наименьший делитель — оно само (не считая 1)
    Подсказка
    Вспомните про оператор % (modulus or остаток от деления) из урока 4. Он вычисляет остаток от деления одного операнда на другой. Например, 11%5 это 1, а 10%2 это 0.

    Так что если x%y это 0, то y делит x без остатка.

    юнит тест
    Код (Javascript):
    1. test('smallestDivisor', () => {
    2.   expect(smallestDivisor(1)).toBe(1);
    3.   expect(smallestDivisor(3)).toBe(3);
    4.   expect(smallestDivisor(4)).toBe(2);
    5.   expect(smallestDivisor(8)).toBe(2);
    6.   expect(smallestDivisor(9)).toBe(3);
    7.   expect(smallestDivisor(17)).toBe(17);
    8.   expect(smallestDivisor(15)).toBe(3);
    9.   expect(smallestDivisor(121)).toBe(11);
    10. });
    мое решение не проходит только первый тест если число "1", не могу понять что не так
    вот мое решение
    Код (Text):
    1. function smallestDivisor(num) {
    2.     function delitel(number, delitelNumber) {
    3.         if(number % delitelNumber === 0) {
    4.             return delitelNumber;
    5.         }else {
    6.             return delitel(number, delitelNumber+1)
    7.         }
    8.     }
    9.     return delitel(num, 2);
    10. }
    если delitelNumber == 1, то не работает скрипт, а если delitelNumber == 2 то не прохожу юнит тест. Помогите решить и если не влом объясните решение, так как эта рекурсия меня в гроб (без практики) сведет
     
    #1 Taktreba, 3 сен 2017
    Последнее редактирование: 3 сен 2017