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

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

Восстановить пароль Регистрация
 
Fiks19
1 / 1 / 0
Регистрация: 07.01.2012
Сообщений: 44
07.01.2012, 14:06     Наилучший делитель #1
В решение задач не сильно понимаю если поможете буду признателен.
Миниатюры
Наилучший делитель  
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
07.01.2012, 14:06     Наилучший делитель
Посмотрите здесь:

Делитель. C++
C++ Общий делитель С++
найти общий делитель C++
C++ делитель
Наихудший делитель. C++
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
Fiks19
1 / 1 / 0
Регистрация: 07.01.2012
Сообщений: 44
09.01.2012, 16:00  [ТС]     Наилучший делитель #2
В С++ я не силен если поможете буду признателен
Этот код находит наихудший делитель
C++
1
2
3
4
5
6
7
8
9
10
11
12
#include <stdio.h>>
#include <string.h>
char a[9999];
main(){
        freopen("input.txt","r",stdin);
        freopen("output.txt","w",stdout);
        scanf("%s",&a);
        printf("1");
        for (int i = strlen(a)-1; i > 0; i--)
                if (a[i]=='0') printf("0"); else break;
        return 0;
}
valeriikozlov
Эксперт C++
 Аватар для valeriikozlov
4660 / 2486 / 321
Регистрация: 18.08.2009
Сообщений: 4,550
09.01.2012, 16:39     Наилучший делитель #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
30
31
32
33
34
#include <stdio.h>
#include <math.h>
int ssum(int a)
{
    int t=0; 
    while(a)
    {
        t+=a%10;
        a/=10;
    }
    return t;
}
main(){
        freopen("input.txt","r",stdin);
        freopen("output.txt","w",stdout);
        int n, i, res, sum=0;
        scanf("%d",&n);
        for(i=1; i<=(int)sqrt((double)n); i++)
            if(n%i==0)
            {
                int t=ssum(i);
                if(t>sum || (t==sum && i<res))
                {
                    res=i; sum=t;
                }
                t=ssum(n/i);
                if(t>sum || (t==sum && n/i<res))
                {
                    res=n/i; sum=t;
                }
            }
        printf("%d", res);        
        return 0;
}
Байт
 Аватар для Байт
13993 / 8824 / 1231
Регистрация: 24.12.2010
Сообщений: 15,990
09.01.2012, 16:48     Наилучший делитель #4
C
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
int Cifr(int x)
{ int s = 0;
while(x>0) {
  s += (x%10);
  s /= 10;
}   
}
bool Best(int a, int b)
{
   int c = Cifr(a) - Cifr(b);
   if (c) return(c>0);
   else return (a>b);
}
main()
{
  int b = 1;
  for(i=2; i<=N; i++) {
    if (N%i) continue;
    if (Best(i, b) b = i;
  }
  cout << b;
}
Yandex
Объявления
09.01.2012, 16:48     Наилучший делитель
Ответ Создать тему
Опции темы

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