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

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

Восстановить пароль Регистрация
 
BF_KARATEL
 Аватар для BF_KARATEL
11 / 11 / 0
Регистрация: 01.06.2012
Сообщений: 114
18.01.2013, 18:36     Алгоритм нахождения цифрового корня натурального числа #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++ алгоритм для вычисления квадратного корня x из вещественного числа y.
Составить программу для нахождения числа, которое образуется из данного натурального числа при записи его цифр в обратном порядке C++
C++ Нахождения корня р степени из а используя реккурентное выражение
C++ с++ нахождения наименьшего натурального
C++ Разработать алгоритм вычисления корня n-ой степени из комплексного числа
C++ Нахождение наименьшего нечетного натурального делителя k (k≠1) любого заданного натурального числа n
C++ Реализовать решение линейного рекуррентного уравнения нахождения числа f (k) для любого натурального k
C++ Разработать алгоритм нахождения четных цифр числа х

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

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
grizlik78
Эксперт С++
 Аватар для grizlik78
1884 / 1416 / 102
Регистрация: 29.05.2011
Сообщений: 2,961
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() функция из библиотеки Си.
Yandex
Объявления
19.01.2013, 00:33     Алгоритм нахождения цифрового корня натурального числа
Ответ Создать тему
Опции темы

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