Форум программистов, компьютерный форум, киберфорум
Наши страницы
С++ для начинающих
Войти
Регистрация
Восстановить пароль
 
Рейтинг 5.00/5: Рейтинг темы: голосов - 5, средняя оценка - 5.00
Leksway1
4 / 4 / 4
Регистрация: 19.05.2014
Сообщений: 56
1

«Целочисленная арифметика»

21.05.2014, 13:21. Просмотров 854. Ответов 3
Метки нет (Все метки)

Благодарен буду кто поможем с задачей
Ниже. Не могу понять что и как вообще, в с ++ желательно

Дано натуральное число N. Найти и вывести все числа в интервале от 1 до N — 1, у которых произведение всех цифр совпадает с суммой цифр данного числа. Если таких чисел нет, то вывести слово «нет». Пример. N = 44. Числа: 18, 24.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
21.05.2014, 13:21
Ответы с готовыми решениями:

Целочисленная арифметика
Нужно переставить старшую и младшую цифры в записи натурального числа. Не могу...

Целочисленная арифметика
Дано натуральное двухзначное число. Получить трехзначные числа, образованные...

Целочисленная арифметика
Помогите пожалуйста в задаче: Найти количество натуральных двузначных чисел,...

Целочисленная арифметика в С++
Вычислить произведение двух чисел. Первое число - сумма третьей и четвертой...

Целочисленная арифметика
1. Найти наибольшую нечетную цифру. Если ее нет, возвратить 0? 2. Определить,...

3
you_rule
56 / 56 / 33
Регистрация: 08.03.2014
Сообщений: 138
21.05.2014, 13:31 2
Лучший ответ Сообщение было отмечено Leksway1 как решение

Решение

Leksway1,
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
39
40
41
#include <iostream>
 
using namespace std;
 
int sum(int nom)
{
    int Sum=0;
    while (nom>0)
    {
        Sum+=nom%10;
        nom/=10;
    }
    return Sum;
}
int proisved(int nom)
{
    int Proisved=1;
    while (nom>0)
    {
        Proisved*=nom%10;
        nom/=10;
    }
    return Proisved;
}
 
int main()
{
    double n;
    int kol=0;
    cin>>n;
    int sumOfN=sum(n);
    for (int i=1;i<n;i++)
        if (proisved(i)==sumOfN)
        {
            cout<<i<<endl;
            kol++;
        }
    if (kol==0)
        cout<<"нет";
    return 0;
}
1
moomot
9 / 9 / 6
Регистрация: 12.07.2013
Сообщений: 57
21.05.2014, 13:40 3
Лучший ответ Сообщение было отмечено Leksway1 как решение

Решение

В примере у Вас ошибка, так как существуют в вашем диапазоне (44) еще цифры 8 и 42

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
#include <iostream>
using namespace std;
int main ()
{
    int n = 0;
 
    cin >> n;
 
    int temp_n = n, sum = 0;
    bool status = false;
 
    while(temp_n > 0)
    {
        sum+=temp_n % 10;
        temp_n/=10;
    }
    for(int i = 1; i < n - 1; i++)
    {
        temp_n = i;
        int proizv = 1;
        while(temp_n > 0)
        {
        proizv *= temp_n % 10;
        temp_n = temp_n / 10;
        }
        if(sum == proizv)
        {
            cout << i << " ";
            status = true;
        }
    }
    if(!status)
    {
        cout << "Нет!";
    }
    return 0;
}
1
Leksway1
4 / 4 / 4
Регистрация: 19.05.2014
Сообщений: 56
21.05.2014, 13:51  [ТС] 4
Спасибо большое вам.
Обоим поставил +
0
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
21.05.2014, 13:51

целочисленная арифметика c++
Как сравнивать цифры в числе который находиться в массиве???

Целочисленная арифметика
Найти на отрезке натуральное число, имеющее наибольшее количество делителей.

Целочисленная арифметика
Вот мне дали задание но я не могу понять что от меня требуется. бьясните как...


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

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2018, vBulletin Solutions, Inc.
Рейтинг@Mail.ru