170 похожих чатов

Здравствуйте, такой вопрос, как можно через рекурсию реализовать нахождение факториала? Такой

код :

#include <iostream>
#include <string>

using namespace std;

int fak(unsigned long long int a) {


if (a == 1 || a ==0) {
return(1);
}


return a * fak(a - 1);


}


int main()
{
setlocale(LC_ALL, "ru");

int a;

cout « "число» ";
cin » a;


cout « "факториал = "«fak(a) « endl;



}

Однако при нахождении факториала более 12, программа работает некорректно. Подскажите пожалуйста, с чем это связано и где допустил ошибки.

4 ответов

14 просмотров

С переполнением int

Ivan- Автор вопроса
Anatoly Shirokov
С переполнением int

То, что long long тоже не поможет?

Ivan
То, что long long тоже не поможет?

Поможет до какого-то предела, но у тебя функция int возвращает. Измени тип возврата на long long

Ivan- Автор вопроса
Anatoly Shirokov
Поможет до какого-то предела, но у тебя функция in...

Понял, программа заработала. Большое спасибо!

Похожие вопросы

Обсуждают сегодня

Ребят в СИ можно реализовать ООП?
Николай
32
Добрый вечер, Пока не совсем понимаю как наладить общение между телеграм ботом и ПО для работы с сим боксом. По самому боту так понял: - Нужен некий баланс, который можно поп...
Magic
6
~ 2m21s  nix shell github:nixos/nixpkgs#stack ~  stack ghc -- --version error: … while calling the 'derivationStrict' builtin at /builtin/derivation.nix:...
Rebuild your mind.
6
Всем доброго вечера. Разрабатываю 32 раз. приложение в Delphi. Столкнулся с тем, что стандартный  TFilestream  не работает с большим файлом > 2 ГБайт (после вызова функции see...
Vadim Gl
16
добрый день. Подскажите, есть сайт на 1.4.7 и я хочу обновиться, особо ничего не меняя. мне выбирать версию 1.4.35 или третью ветку? и можно ли обновлять "как есть", или нужно...
Digital Cat
12
народ, плиз хелп, всю голову сломал себе уже... разве может быть так, что GetProcAddress( GetModuleHandle( "kernel32.dll" ), "SetThreadDescription" ) вернёт ненулевое значение...
Iluha Companets
12
Всем привет! Имеется функция: function IsValidChar(ch: UTF8Char): Boolean; var i: Integer; ValidChars: AnsiString; begin ValidChars := 'abcdefghijklmnopqrstuvwxyzABCDE...
Евгений
44
а плаксы из-под питона умеют только в комфортных условиях что-то выдавить из себя?)
Lencore
9
Кстати, что за тип булеана, который в памяти как 00 для фолса и 01 для тру отображается? Однобайтовый
Serjone
8
ребят подскажите почему матрица не транспонируется? #define _CRT_SECURE_NO_WARNINGS #include <stdio.h> #include <math.h> #include <locale.h> #define N 7 int main() { int...
† C E †
1
Карта сайта