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

Наилучший делитель - C++

Восстановить пароль Регистрация
 
Aerarian
1 / 1 / 0
Регистрация: 28.06.2016
Сообщений: 78
09.07.2016, 16:12     Наилучший делитель #1
Будем говорить, что число a лучше числа b, если сумма цифр a больше суммы цифр числа b, а в случае равенства сумм их цифр, если число a меньше числа b. Например, число 124 лучше числа 123, так как у первого из них сумма цифр равна семи, а у второго – шести. Также, число 3 лучше числа 111, так как у них равны суммы цифр, но первое из них меньше.
Дано число n. Найдите такой его делитель (само число n и единица считаются делителями числа n), который лучше любого другого делителя числа n.
Лучшие ответы (1)
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
09.07.2016, 16:12     Наилучший делитель
Посмотрите здесь:

Делитель. C++
C++ Общий делитель С++
Наибольший общий делитель на С++ C++
C++ делитель
Наихудший делитель. C++
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
_Ivana
2177 / 1382 / 124
Регистрация: 01.03.2013
Сообщений: 4,122
Записей в блоге: 2
09.07.2016, 16:37     Наилучший делитель #2
C++
1
2
3
4
int s(int a) {return a ? a%10 + s(a/10) : 0;}
int g(int a, int b) {int r=s(a)-s(b); return r>0 ? a : r<0 ? b : min(a,b);}
int t(int i, int n, int r) {return i>n ? r : t(i+1, n, n%i ? r : g(r, i));}
int main() {int n; cin>>n; cout << t(1,n,1);}
shilko2013
 Аватар для shilko2013
237 / 214 / 115
Регистрация: 02.04.2016
Сообщений: 812
Завершенные тесты: 1
09.07.2016, 16:41     Наилучший делитель #3
Сообщение было отмечено автором темы, экспертом или модератором как ответ
Вроде работает
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
#include <iostream>
int sum (int n) {
    int sum=0,d;
    while (n>0) {
        d = n % 10;
        sum += d;
        n = n / 10;
    }
    return sum;
}
int main () {
    int n,d=-1;
    cin >> n;
    for (int i=2;i<n;i++) { //если не считать 1 и само число делителями.
        if (n % i == 0)
            if (sum(i)>sum(d))
                d = a;
            else if ((sum(i)=sum(d)) && (i<d))
                    d = a;
    }
}
Mr.X
Эксперт С++
 Аватар для Mr.X
2799 / 1575 / 246
Регистрация: 03.05.2010
Сообщений: 3,656
09.07.2016, 19:47     Наилучший делитель #4
На самом деле, если мы рассматриваем делители от меньших к большим, то вариант с равными суммами цифр рассматривать не нужно, так как если они совпадут, то у нас уже выбран меньший.
shilko2013
 Аватар для shilko2013
237 / 214 / 115
Регистрация: 02.04.2016
Сообщений: 812
Завершенные тесты: 1
11.07.2016, 14:14     Наилучший делитель #5
Mr.X, Точно!
Yandex
Объявления
11.07.2016, 14:14     Наилучший делитель
Ответ Создать тему
Опции темы

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