Форум программистов, компьютерный форум, киберфорум
C# для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.60/15: Рейтинг темы: голосов - 15, средняя оценка - 4.60
0 / 0 / 0
Регистрация: 23.10.2012
Сообщений: 9

Рекурсия. Нахождение факториала числа

18.11.2012, 15:01. Показов 2875. Ответов 7
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
static int Factorial(int n)
        {
            if (n == 0 || n == 1)
            {
                return 1;
            }
            else return n * Factorial(n - 1);
        }
 
        static void Main(string[] args)
        {
            Console.Write("Введите число для нахождения факториала: ");
            int iFactorial = int.Parse(Console.ReadLine());
            int iFactorialResult = Factorial(iFactorial);
            Console.WriteLine("{0}!={1}",iFactorial, iFactorialResult);
            Console.ReadKey();        
        }
Объясните, пожалуйста, с каждой итерацией число n уменьшается на 1, тогда почему при n=1, в iFactrorialResult не присваивается значение 1?
C#
1
2
3
4
if (n == 0 || n == 1)
            {
                return 1;
            }
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
18.11.2012, 15:01
Ответы с готовыми решениями:

Рекурсия для факториала
Задание В класс MyMathClass поместите рекурсивную функцию Factorial() вычисления факториала натурального числа, которая будет принимать...

Рекурсия. Функция вычисления факториала
Решить задачу в приложении Windows Forms:

Нахождение факториала
Здравствуйте. Написал метод нахождения факториала. Но не понятно вот что. До числа 12 включительно все считает хорошо. Но потом начинается...

7
Эксперт .NET
 Аватар для kolorotur
17823 / 12973 / 3382
Регистрация: 17.09.2011
Сообщений: 21,261
18.11.2012, 15:16
Цитата Сообщение от elbrusoft Посмотреть сообщение
почему при n=1, в iFactrorialResult не присваивается значение 1?
А какое значение ему присваивается?
0
0 / 0 / 0
Регистрация: 23.10.2012
Сообщений: 9
18.11.2012, 15:23  [ТС]
kolorotur, нормальное для факториала)
К примеру для 4!=24
0
Эксперт .NET
 Аватар для kolorotur
17823 / 12973 / 3382
Регистрация: 17.09.2011
Сообщений: 21,261
18.11.2012, 15:32
А причем здесь четыре?
Вы же пишете:

Цитата Сообщение от elbrusoft Посмотреть сообщение
почему при n=1, в iFactrorialResult не присваивается значение 1?
Само-собой возникает встречный вопрос: а какое значение ему присваивается, если не единица?
0
0 / 0 / 0
Регистрация: 23.10.2012
Сообщений: 9
18.11.2012, 15:53  [ТС]
kolorotur, iFactorialResult служит для нахождения факториала от числа iFactorial. Вы наверное не поняли вопрос. В методе Factorial используется рекурсия, в теле которой лежит n-1, я спрашиваю почему при достижении n=1 или 0, в основную программу не возвращается 1. На примере того же 4!=24, ведь n Будет принимать след. значения: 3,2,1. А в теле стоит условие: при n==1 return 1. Так вот, почему в iFactorialResult не возвращается 1?Ведь по идее так и должно произойти?
0
 Аватар для Sickprick
5 / 5 / 5
Регистрация: 14.11.2012
Сообщений: 13
18.11.2012, 16:17
Цитата Сообщение от elbrusoft Посмотреть сообщение
kolorotur, iFactorialResult служит для нахождения факториала от числа iFactorial. Вы наверное не поняли вопрос. В методе Factorial используется рекурсия, в теле которой лежит n-1, я спрашиваю почему при достижении n=1 или 0, в основную программу не возвращается 1. На примере того же 4!=24, ведь n Будет принимать след. значения: 3,2,1. А в теле стоит условие: при n==1 return 1. Так вот, почему в iFactorialResult не возвращается 1?Ведь по идее так и должно произойти?
Рекурсия - это вызов функции самой себя и создание нового экземпляра этой же функции с другими параметрами. Созданный экземпляр выполняет какое либо действие и возвращает результат в вызывавший его экземпляр.
Factorial (1) = 1
Экземпляр Factorial(1) был вызван экземпляром Factorial(2) (а тот, в свою очередь, Factorial(3) и т.д), следовательно 1 вернется в Factorial(2), а не в конечную функцию.
0
Эксперт .NET
 Аватар для kolorotur
17823 / 12973 / 3382
Регистрация: 17.09.2011
Сообщений: 21,261
18.11.2012, 17:03
Цитата Сообщение от elbrusoft Посмотреть сообщение
почему в iFactorialResult не возвращается 1?
Я терпеливый, потому спрошу третий раз: если не возвращается 1, то что возвращается при n == 1?
0
0 / 0 / 0
Регистрация: 23.10.2012
Сообщений: 9
18.11.2012, 18:42  [ТС]
kolorotur, выше уже ответили, то что я хотел услышать
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
18.11.2012, 18:42
Помогаю со студенческими работами здесь

Нахождение факториала.
Не получается написать программу, которая бы искала факториал числа, с циклом for. Я не знаю как сделать так, чтобы после прохождения...

Задача на нахождение факториала
Помогите, пожалуйста, с написанием программного кода на нахождение факториала (язык программирования C#) . Условие:

Вычисление факториала из числа
Доброго времени суток... Никак не могу понять - вычисления факториала с этой рекурсией, вот именно процесс вычисления и самой рекурсии не...

Рекурсия: нахождение двойного факториала
вот не знаю,как описать рекурсивную функцию нахождения двойного факториала.. вот мой вариант,он он естественно не правильный)) ...

Рекурсия: нахождение двойного факториала
Помогите пожалуйста как это можно написать. Y=(2*n+1)!!*(2*m+1)!!/(2*(m+n)+1)!!,где m,n неотрицательные целые числа.Для определения...


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

Или воспользуйтесь поиском по форуму:
8
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Обработчик клика мыши в браузере ПК и касания экрана в браузере на мобильном устройстве
8Observer8 02.02.2026
Содержание блога Для начала пошагово создадим рабочий пример для подготовки к экспериментам в браузере ПК и в браузере мобильного устройства. Потом напишем обработчик клика мыши и обработчик. . .
Философия технологии
iceja 01.02.2026
На мой взгляд у человека в технических проектах остается роль генерального директора. Все остальное нейронки делают уже лучше человека. Они не могут нести предпринимательские риски, не могут. . .
SDL3 для Web (WebAssembly): Вывод текста со шрифтом TTF с помощью SDL3_ttf
8Observer8 01.02.2026
Содержание блога В этой пошаговой инструкции создадим с нуля веб-приложение, которое выводит текст в окне браузера. Запустим на Android на локальном сервере. Загрузим Release на бесплатный. . .
SDL3 для Web (WebAssembly): Сборка C/C++ проекта из консоли
8Observer8 30.01.2026
Содержание блога Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
SDL3 для Web (WebAssembly): Установка Emscripten SDK (emsdk) и CMake для сборки C и C++ приложений в Wasm
8Observer8 30.01.2026
Содержание блога Для того чтобы скачать Emscripten SDK (emsdk) необходимо сначало скачать и уставить Git: Install for Windows. Следуйте стандартной процедуре установки Git через установщик. . . .
SDL3 для Android: Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 29.01.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами. Версия v3 была полностью переписана на Си, в. . .
Инструменты COM: Сохранение данный из VARIANT в файл и загрузка из файла в VARIANT
bedvit 28.01.2026
Сохранение базовых типов COM и массивов (одномерных или двухмерных) любой вложенности (деревья) в файл, с возможностью выбора алгоритмов сжатия и шифрования. Часть библиотеки BedvitCOM Использованы. . .
SDL3 для Android: Загрузка PNG с альфа-каналом с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 28.01.2026
Содержание блога SDL3 имеет собственные средства для загрузки и отображения PNG-файлов с альфа-каналом и базовой работы с ними. В этой инструкции используется функция SDL_LoadPNG(), которая. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru