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

Найти все пары «дружественных чисел», которые не больше данного числа - C++

Восстановить пароль Регистрация
 
Рейтинг: Рейтинг темы: голосов - 13, средняя оценка - 5.00
пока что чайник
1 / 1 / 0
Регистрация: 15.02.2011
Сообщений: 41
15.05.2011, 21:27     Найти все пары «дружественных чисел», которые не больше данного числа #1
Два натуральных числа называются «дружественными», если каждое из них равно сумме всех делителей (кроме его самого) другого (например, числа 220 и 284). Найти все пары «дружественных чисел», которые не больше данного числа N.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
15.05.2011, 21:27     Найти все пары «дружественных чисел», которые не больше данного числа
Посмотрите здесь:

Найти все пары дружественных чисел в диапазоне от 200 до 300 C++
Найти все пары «дружественных чисел», которые не больше данного числа/ на C++ C++
C++ Напечатать все пары дружественных чисел
C++ Найти все пары дружественных чисел, не превосходящих заданного натурального числа N
Найти все пары двузначных чисел, которые, будучи записанными подряд, дают четырёхзначное число, нацело делящееся на сумму данных чисел C++
Найти все пары дружественных натуральных чисел из интервала от N 1 до N 2. C++
C++ Найти все пары дружественных чисел, лежащих в диапазоне от 200 до 300
Из заданного интервала натуральных чисел выбрать и напечатать все пары дружественных чисел C++

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

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
silent_1991
Эксперт C++
4938 / 3014 / 149
Регистрация: 11.11.2009
Сообщений: 7,024
Завершенные тесты: 1
15.05.2011, 22:14     Найти все пары «дружественных чисел», которые не больше данного числа #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
28
29
30
31
32
33
34
35
36
37
38
#include <iostream>
 
typedef unsigned long long ull_t;
 
ull_t sum_of_divs(ull_t);
bool is_friendly(ull_t, ull_t);
 
int main()
{
    ull_t left = 1;
    ull_t right;
 
    std::cout << "Enter N: ";
    std::cin >> right;
 
    for (ull_t num1 = left; num1 <= right; ++num1)
        for (ull_t num2 = num1 + 1; num2 <= right; ++num2)
            if (is_friendly(num1, num2))
                std::cout << num1 << "\t" << num2 << std::endl;
 
    return 0;
}
 
ull_t sum_of_divs(ull_t number)
{
    ull_t sum = 0;
 
    for (ull_t d = 1; d < number / 2 + 1; ++d)
        if (number % d == 0)
            sum += d;
 
    return sum;
}
 
bool is_friendly(ull_t number1, ull_t number2)
{
    return sum_of_divs(number1) == number2 && sum_of_divs(number2) == number1;
}
Yandex
Объявления
15.05.2011, 22:14     Найти все пары «дружественных чисел», которые не больше данного числа
Ответ Создать тему
Опции темы

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