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

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

Войти
Регистрация
Восстановить пароль
 
BF_KARATEL
11 / 11 / 0
Регистрация: 01.06.2012
Сообщений: 114
#1

Алгоритм нахождения цифрового корня натурального числа - C++

18.01.2013, 18:36. Просмотров 813. Ответов 1
Метки нет (Все метки)

хочу сделать проверку числа что бы выводилось сообщение при большем числе не получается

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
void zadanie_3()
{
signed long n;
clrscr();
cout<<"\n vvedite chislo: ";
cin>>n;
 
if(n<0)
  n*=-1;
 
if(n>2147483647)
 cout<<"\n Vvedeno bolhoe chislo (diapozon ot -2147483648 do 2147483647) !";
else
{
cout<<"n= "<<n;
 
if(n>9)
 n=(n-1)%9+1;
cout<<"\n cifrovoi koren= "<<n;
}
 
cout<<"\n\n Dli vixoda v menu nagmite lubyu klavihy";
getch();
clrscr();
}
Миниатюры
Алгоритм нахождения цифрового корня натурального числа  
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
18.01.2013, 18:36     Алгоритм нахождения цифрового корня натурального числа
Посмотрите здесь:

Нахождение цифрового корня заданного числа (оптимизировать код) - C++
Здравствуйте! Вот интересная задачка на циклы. Но во многих тестах по времени не проходит...Что я делаю не так?:( Условие: ...

Написать рекурсивную функцию для нахождения произведения цифр натурального числа - C++
.Написать рекурсивную функцию для нахождения произведения цифр натурального числа. С помощью этой функции найти произведения цифр пяти...

алгоритм для вычисления квадратного корня x из вещественного числа y. - C++
Составить блок-схему алгоритма для вычисления квадратного корня x из вещественного числа y. Примечание. Вычисление квадратного корня...

Разработать алгоритм вычисления корня n-ой степени из комплексного числа - C++
В общем нужно на любом языке накатать программу: Разработать алгоритм вычисления корня n-ой степени из комплексного числа. Помогите мне...

Реализовать решение линейного рекуррентного уравнения нахождения числа f (k) для любого натурального k - C++
На вычислительной практие дали такое задание: Напишите программу, реализующую решение линейного рекуррентного уравнения нахождения...

Разработать алгоритм нахождения четных цифр числа х - C++
Разработать алгоритм нахождения четных цифр числа х

Нахождение наименьшего нечетного натурального делителя k (k≠1) любого заданного натурального числа n - C++
Помогите с этой задачой: Подпрограммы Составить функцию для нахождения наименьшего нечетного натурального делителя k (k≠1) любого...

Комбинированный метод нахождения корня уравнения - C++
Всем здравствуйте, у меня такая проблема: при выводе результата на экран, в зависимости от вводимых значений, происходит &quot;зависание&quot;...

Нахождения корня р степени из а используя реккурентное выражение - C++
Здравствуйте. На лабораторной попался такой вариант: http://savepic.su/1642399m.png Вот собственно набросал код: #include...

с++ нахождения наименьшего натурального - C++
Составьте программу нахождения наименьшего натурального N-значного числа X(X&gt;=10), равного утроенному произведения своих цифр

Умножение цифр каждого 6 цифрового числа - C++
вывести на экран умножение цифр каждого 6 цифрового числа от 100 000 ... 999 999 И как всегда не правильно результат выводит. unsigned...

Проверить условия совпадения и записать расчетные формулы для нахождения корня уравнения с заданной точностью - C++
1) Проверить условия совпадения и записать расчетные формулы для нахождения корня уравнения с точностью ε = 10 -4. 2) Составить...


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

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
grizlik78
Эксперт С++
1908 / 1440 / 110
Регистрация: 29.05.2011
Сообщений: 2,995
19.01.2013, 00:33     Алгоритм нахождения цифрового корня натурального числа #2
Когда число уже неправильно преобразовалось, то поздно проверять его. Можно вводить число как строку и преобразовывать его функцией strtol(), которая сообщает об ошибке.
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 <cerrno>
#include <limits>
 
using namespace std;
 
int main()
{
    signed long n;
    string str;
 
    cout << "\n vvedite chislo: ";
    cin >> str;
 
    char *endptr;
    errno = 0;
    n = strtol(str.c_str(), &endptr, 10);
 
    if (errno != 0 || n == numeric_limits<long>::min())
    {
        if (errno == ERANGE || errno == 0)
            cout<<"\n Vvedeno bolhoe chislo (diapozon ot " << numeric_limits<long>::min() + 1
                << " do " << numeric_limits<long>::max() << ") !";
        else
            cout<<"\n Input error";
    }
    else
    {
        if (n < 0)
            n *= -1;
 
        cout << "n= " << n;
 
        if (n > 9)
            n = (n-1) % 9 + 1;
        cout << "\n cifrovoi koren= " << n;
    }
 
    cout << "\n\n Dli vixoda v menu nagmite lubyu klavihy";
 
    return 0;
}
Подозреваю, что старый компилятор может не знать про string, numeric_limits и т. п., но это в данном коде не главное, принцип преобразования такой же, так как strtol() функция из библиотеки Си.
Ответ Создать тему
Опции темы

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