Форум программистов, компьютерный форум, киберфорум
Pascal (Паскаль)
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 5.00/7: Рейтинг темы: голосов - 7, средняя оценка - 5.00
1 / 1 / 0
Регистрация: 17.05.2009
Сообщений: 104

Факториала

25.12.2009, 19:18. Показов 1523. Ответов 8
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Нужно написать функцию факториала .
Скажите пжл что нужно изменить чтоб правильно считала.
Pascal
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
program Project457;
 
uses crt;
var o,n:integer;
 
function fact(n:integer):longint;
begin
if n=1 then fact:=1
         else fact:=fact(n-1)*n;
end;
 
begin
write('vvedi chislo: ');
readln(n);
o:=fact(n);
writeln('otvet:', o);
readln;
end.
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
25.12.2009, 19:18
Ответы с готовыми решениями:

Вычисление факториала
Данная программа написана для вычисления факториала числа n. По определению факториал n равен 1*2*…*(n–1)*n. var n, f, k: integer; ...

Вычисления факториала
ребят подскажите...правильно ли составлен цикл вычиcления (2n)! Спасибо uses crt; var i,n:integer; s:real; Begin; clrscr; ...

Вычисление факториала
Напишите функцию, вычисляющую факториал числа n!=1×2×3×....×n. В паскале нкжно Помогите , заранее огромное спасибо

8
 Аватар для yanyk1n
4342 / 1474 / 680
Регистрация: 12.03.2009
Сообщений: 5,310
25.12.2009, 19:21
Pascal
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
program Project457;
 
uses crt;
var o,n:integer;
 
function fact(n:integer):longint;
begin
if (n=1) or (n=0) then fact:=1 //0!=1; 1!=1
         else fact:=fact(n-1)*n;
end;
 
begin
write('vvedi chislo: ');
readln(n);
o:=fact(n);
writeln('otvet:', o);
readln;
end.
1
 Аватар для Aye Aye
373 / 287 / 97
Регистрация: 17.12.2009
Сообщений: 567
25.12.2009, 19:22
все нормально работатет, только в 8-ой строчке надо:
Pascal
1
if n=0 then fact:=1
ибо иначе fact(0) не сработает а по определению 0!=1
1
 Аватар для Vladiator
1574 / 645 / 79
Регистрация: 24.02.2009
Сообщений: 9,268
25.12.2009, 19:22
HERON, код можно укоротить:
Pascal
1
2
3
4
5
6
7
8
9
10
11
12
13
uses crt;
var n:integer;
function fact(n:integer):longint;
begin
if n<2 then fact:=1
         else fact:=fact(n-1)*n;
end;
begin
write('vvedi chislo: ');
readln(n);
writeln('otvet: ', fact(n));
readln;
end.
1
UNIX-way
 Аватар для Delphin_KKC
712 / 495 / 49
Регистрация: 15.01.2009
Сообщений: 1,720
25.12.2009, 19:25
Согласно этого: факториал на Вики
0!=1
значит нужно так:
Pascal
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
program Project457;
 
uses crt;
var o,n:integer;
 
function fact(n:integer):longint;
begin
if n=0 then fact:=1 //учитываем 0!=1
 else if n < 0 then fact:=-1 //если n отрицательное - возвращаем код ошибки (-1)
         else fact:=fact(n-1)*n;
end;
 
begin
write('vvedi chislo: ');
readln(n);
o:=fact(n);
if o=-1 then writeln('oshibka!') else
 writeln('otvet:', o);
readln;
end.
1
1 / 1 / 0
Регистрация: 17.05.2009
Сообщений: 104
25.12.2009, 19:26  [ТС]
Спасибо всем за помощь
0
11 / 11 / 7
Регистрация: 23.12.2009
Сообщений: 300
25.12.2009, 19:37
fact(n-1)*n; ето не факториал
факториал N = 1*2*3*...*N

вот так

Pascal
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
 program Project457;
 
uses crt;
var o,n:integer;
 
function FAKA(n:integer):longint;
 var i:integer;
begin
 FAKA:=0;
 for i:=1 to n do FAKA:=FAKA*i;
end;
 
begin
write('vvedi chislo: ');
readln(n);
('Otvet' ,FAKA(n));
readln;
end.
0
 Аватар для Vladiator
1574 / 645 / 79
Регистрация: 24.02.2009
Сообщений: 9,268
25.12.2009, 19:39
Hovercat, РЕКУРСИЯ!!!!!!!! правильно у него всё. твой вариант не быстрый.
0
UNIX-way
 Аватар для Delphin_KKC
712 / 495 / 49
Регистрация: 15.01.2009
Сообщений: 1,720
25.12.2009, 19:41
Цитата Сообщение от Hovercat Посмотреть сообщение
fact(n-1)*n; ето не факториал
факториал N = 1*2*3*...*N
...
Очень даже факториал. Просто рекурсивный алгоритм.
Рекурсия на Вики

Добавлено через 1 минуту
Цитата Сообщение от Kidalvь Посмотреть сообщение
... твой вариант не быстрый.
За то стека меньше расходует. Хотя для таких программ это малокритично.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
25.12.2009, 19:41
Помогаю со студенческими работами здесь

Возведение факториала в степень
Возведение факториала в степень, запрещено использовать функцию sqr. an = (n!)n, где n! = 1 ∙ 2 ∙ ... ∙ n.

Значение двойного факториала
Возникли осложнения с решением этой задачи, пожалуйста помогите: Описать функцию Fact2(N) целого типа, вычисляющую значение...

Вычисление факториала. Сasе
Вычислите факториал 5,12,17 и через case вывести ответ. Пожалуйста, подредактируйте программу, не могу никак с ней справиться. Да,и на...

Вычислить значение факториала
Описать процедуру и функцию Fact(N) вещественного типа, вычисляющую значение факториала N! = 1·2·…·N (N &gt; 0 — параметр целого типа;...

решение факториала в паскале
решить двойной факториал по формуле стирлинга


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

Или воспользуйтесь поиском по форуму:
9
Ответ Создать тему
Новые блоги и статьи
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
Мысли в слух
kumehtar 18.11.2025
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
Создание Single Page Application на фреймах
krapotkin 16.11.2025
Статья исключительно для начинающих. Подходы оригинальностью не блещут. В век Веб все очень привыкли к дизайну Single-Page-Application . Быстренько разберем подход "на фреймах". Мы делаем одну. . .
Фото: Daniel Greenwood
kumehtar 13.11.2025
Расскажи мне о Мире, бродяга
kumehtar 12.11.2025
— Расскажи мне о Мире, бродяга, Ты же видел моря и метели. Как сменялись короны и стяги, Как эпохи стрелою летели. - Этот мир — это крылья и горы, Снег и пламя, любовь и тревоги, И бескрайние. . .
PowerShell Snippets
iNNOKENTIY21 11.11.2025
Модуль PowerShell 5. 1+ : Snippets. psm1 У меня модуль расположен в пользовательской папке модулей, по умолчанию: \Documents\WindowsPowerShell\Modules\Snippets\ А в самом низу файла-профиля. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru