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

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

Войти
Регистрация
Восстановить пароль
 
ВалентинАматор
2 / 5 / 0
Регистрация: 25.02.2011
Сообщений: 140
#1

Найти факториал - C++

10.04.2011, 21:00. Просмотров 773. Ответов 7
Метки нет (Все метки)

Хотел написать программу для нахождения n!.Где мы вводим n.
Возникла трудность с повторением умножения на (n-1)-1)пока не будет 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
26
#include "stdafx.h"
#include "iostream"
using namespace std;
 
 
int _tmain(int argc, _TCHAR* argv[])
{
  int factorial;
  int n=0;
  int N=0;
  cout << "n= ";
  cin >> n;
  
  if(n==1)
  {
 cout << " factorial=1";
  }
  else
  {
factorial=((n-1)?(n-1):1);
  N=n*factorial;
  cout << "factorial = "<<N;
  }
   
    return 0;
}
0
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
10.04.2011, 21:00
Здравствуйте! Я подобрал для вас темы с ответами на вопрос Найти факториал (C++):

Описать рекурсивные функции вещественного типа, вычисляющие факториал и двойной факториал заданного числа - C++
Описать рекурсивные функции Fact(N) и Fact2(N) вещественного типа, вычисляющие значения факториала N! и двойного факториала N!!...

Найти факториал числа - C++
помогите!пожалуйста!=)

Найти факториал индекса - C++
#include &lt;iostream&gt; using namespace std; int main () { setlocale (0,&quot;.1251&quot;); int A, f, imax=0, max, ind=0; cout &lt;&lt;...

Найти факториал с использованием цикла for - C++
Задача 5. (1-5.cpp, 15.dsp) *Написать программу вычисления факториала числа (n!) с использованием цикла for. Использовать форматированный...

Найти факториал с помощью рекурсии - C++
Помогите написать программу с комментариями (Рекурсия) Найти факториал указанного числа.

Найти значание выражения(двойной факториал) - C++
Найти значение выражения . (Определить функцию для расчета двойного факториала натурального числа следующим образом: n!!=1*3*5*…*n, если n...

Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
ailia
27 / 26 / 1
Регистрация: 27.12.2009
Сообщений: 106
10.04.2011, 21:03 #2
надо либо использовать цикл, либо рекурсивную функцию.

пример рекурсивной функции:
C++
1
2
3
4
int fact(int n)
{
return n == 1 ? 1 : n*fact(n - 1);
}
0
IrineK
Заблокирован
10.04.2011, 21:23 #3
Вам не нужен оператор условия, вам нужен оператор цикла.
C++
1
2
3
N = 1;
for(i=1;i<n+1;i++)
   N *= i;
Добавлено через 18 минут
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
#include <iostream>
using namespace std;
  
int main()
{ int i,n, N=1;
  cout << "n= ";
  cin >> n;
  
  for(i=1;i<n+1;i++)
  N *= i;
 
  cout <<n<<"! = "<<N<<"\n";
 
  cin.sync(); cin.get();
  return 0;
}
В одном из своих постов вы оценили свои знания на 6 по 12-бальной шкале.
Вызывает возражения. )
0
ВалентинАматор
2 / 5 / 0
Регистрация: 25.02.2011
Сообщений: 140
10.04.2011, 21:50  [ТС] #4
Я примерно так и думал.Вобще да я наверно переоценил.Пожалуй где то 3)).И я все еще ищу репетитора.))

Добавлено через 8 минут
Кстати что делает вот эта строчка.
C++
1
cin.sync(); cin.get();
0
MrGluck
Модератор
Эксперт CЭксперт С++
7239 / 4407 / 642
Регистрация: 29.11.2010
Сообщений: 11,927
10.04.2011, 21:52 #5
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
#include<iostream>
#include<clocale>
#include<conio.h>
using namespace std;
 
unsigned long fact(unsigned int n){ 
             if(n <= 1)
             return 1;
             else 
             return n * fact(n - 1);
}
 
int main(){
    setlocale(LC_ALL,"Russian");
    unsigned int n;
    cout<<"Введите n: ";
    cin>>n;
    cout<<"С использованием рекурсивной функции !n="<<fact(n);
    if(n!=1)
    for(unsigned int n1=n;n1>1;n1--)
          n*=(n1-1);
    cout<<"\nС использованием цикла !n="<<n;
    getch();
}
1
IrineK
Заблокирован
10.04.2011, 22:22 #6
что делает вот эта строчка: cin.sync(); cin.get();
То же, что у MrGluck - getch();

Задерживает консоль для просмотра результата.
0
silent_1991
Эксперт С++
4964 / 3040 / 149
Регистрация: 11.11.2009
Сообщений: 7,027
Завершенные тесты: 1
10.04.2011, 22:37 #7
Для разнообразия - факториал времени компиляции)))

C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
#include <iostream>
 
template< unsigned long long N >
unsigned long long factorial()
{
    return N * factorial< N - 1 >();
}
 
template< >
unsigned long long factorial< 0 >()
{
    return 1;
}
 
int main()
{
    std::cout << factorial< 5 >() << std::endl;
 
    return 0;
}
0
taras atavin
Ушёл с форума.
3569 / 1753 / 91
Регистрация: 24.11.2009
Сообщений: 27,619
11.04.2011, 07:29 #8
Ну и ну!
C++
1
2
3
4
5
6
7
8
hyper factorial (int n)
{
 if (n==0)
 {
  return 1;
 }
 return factorial(n-1)*n;
}
0
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
11.04.2011, 07:29
Привет! Вот еще темы с ответами:

Найти факториал, используя пользовательский тип - C++
Найти факториал n!=1*2*3...*n решить через классы,

Найти факториал числа заданного условием - C++
Вычислить R=p! , где p третье по счету число ,делящееся на 9 в диапазоне от M1 до M2 Давайте своим темам осмысленные названия!

Дано целое число N (> 0). Найти двойной факториал N: - C++
Всем Доброго дня!!!!!! 1. Дано целое число N (&gt; 0). Найти двойной факториал N: N!! = N•(N–2)•(N–4)•… (последний сомножитель равен...

Найти факториал числа, пользуясь только указателями - C++
В общем задание - &quot;Найти факториал числа, пользуясь только указателями.&quot; Код написал, но не могу понять в чем ошибка. (Error 1 error...


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

Или воспользуйтесь поиском по форуму:
Yandex
Объявления
11.04.2011, 07:29
Ответ Создать тему
Опции темы

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