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

С++ для начинающих

Войти
Регистрация
Восстановить пароль
 
Рейтинг: Рейтинг темы: голосов - 11, средняя оценка - 4.64
B@bruych@n1n
0 / 0 / 0
Регистрация: 22.04.2010
Сообщений: 21
#1

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

27.11.2010, 13:15. Просмотров 1325. Ответов 2
Метки нет (Все метки)

Помргите, пожалуста, решить задачу:
С помощью признака делимости на 11 проверить, кратно ли заданное натуральное число 11. Реализовать рекурсивную функцию.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
27.11.2010, 13:15     Признак делимости и рекурсия
Посмотрите здесь:

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

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

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
silent_1991
Эксперт C++
4949 / 3025 / 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
3021 / 1677 / 265
Регистрация: 03.05.2010
Сообщений: 3,867
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     Признак делимости и рекурсия
Ответ Создать тему
Опции темы

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