Форум программистов, компьютерный форум CyberForum.ru

Признак делимости и рекурсия - C++

Восстановить пароль Регистрация
 
Рейтинг: Рейтинг темы: голосов - 11, средняя оценка - 4.64
B@bruych@n1n
0 / 0 / 0
Регистрация: 22.04.2010
Сообщений: 21
27.11.2010, 13:15     Признак делимости и рекурсия #1
Помргите, пожалуста, решить задачу:
С помощью признака делимости на 11 проверить, кратно ли заданное натуральное число 11. Реализовать рекурсивную функцию.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
27.11.2010, 13:15     Признак делимости и рекурсия
Посмотрите здесь:

C++ Нахождение критерия делимости
Проверить признак делимости на 3 на примере заданного числа C++
Не работает признак окончания ввода(признак-0) C++
C++ признак делимости на три C++
Проверка делимости чисел C++
C++ Графическое изображение делимости
Функция проверки признаков делимости C++
Проверка делимости 1,11,111,.,11.1 на их позиции C++

Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
silent_1991
Эксперт C++
4938 / 3014 / 149
Регистрация: 11.11.2009
Сообщений: 7,024
Завершенные тесты: 1
27.11.2010, 14:05     Признак делимости и рекурсия #2
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
bool div11(int n)
{
    int n1 = 0, n2 = 0;
 
    while (n != 0)
    {
        n1 += n % 10;
        n /= 10;
 
        if (n == 0)
            break;
 
        n2 += n % 10;
        n /= 10;
    }
 
    n = n2 - n1;
    n = n > 0 ? n : -n;
 
    if (n == 0)
        return true;
 
    if (n > 0 && n < 11)
        return false;
 
    return div11(n);
}
Mr.X
Эксперт С++
 Аватар для Mr.X
2803 / 1579 / 247
Регистрация: 03.05.2010
Сообщений: 3,670
27.11.2010, 18:44     Признак делимости и рекурсия #3
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
//////////////////////////////////////////////////////////////////////////////////////
#include <iostream>
//////////////////////////////////////////////////////////////////////////////////////
bool  is_multiple_of_11(int  n)
{
    return n >= 11 ? is_multiple_of_11(n / 10 - n % 10) : n == 0;
}
//////////////////////////////////////////////////////////////////////////////////////
int main()
{
    std::locale::global(std::locale(""));
    for(;;)
    {
        int n = 0;
        do
        {
            std::cout << "Введите целое n >= 0: ";
            std::cin >> n;
        }while(n < 0);       
        
        std::cout << "Число "
                  << n
                  << (is_multiple_of_11(n) ? "" : " НЕ")
                  << " делится на 11."
                  << std::endl
                  << std::endl
                  << std::endl;    
    }
}
Yandex
Объявления
27.11.2010, 18:44     Признак делимости и рекурсия
Ответ Создать тему
Опции темы

Текущее время: 03:13. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru