|
|
Регистрация Восстановить пароль |
Повторная активизация e-mail |
Регистрация | Задать вопрос |
Заплачу за решение |
Новые сообщения |
Сообщения за день |
Расширенный поиск |
Правила |
Всё прочитано |
Нет наработок или кода, если нужно готовое решение - создайте тему в разделе Фриланс и оплатите работу. Название темы включает слова - "Помогите", "Нужна помощь", "Срочно", "Пожалуйста". Название темы слишком короткое или не отражает сути вашего вопроса. Тема исчерпала себя, помните, один вопрос - одна тема Прочитайте правила и заново правильно создайте тему. |
|
Опции темы | Поиск в этой теме |
24.03.2009, 01:31 | #1 |
Пользователь
Регистрация: 21.03.2009
Сообщений: 35
|
вычисление факториала (Pascal)
Еще раз здравствуйте. Вот такая задача:
Вычислить значение n! для n, введенного с клавиатуры. Вот мой код: Код:
|
24.03.2009, 01:32 | #2 |
Участник клуба
Регистрация: 10.11.2008
Сообщений: 1,502
|
Код:
Нормальное состояние техники - нерабочее, все остальное частный случай.
|
24.03.2009, 03:54 | #3 |
Пользователь
Регистрация: 21.03.2009
Сообщений: 35
|
Честно говоря, не очень. Отличие моего и Вашего кода только в сравнении k и n, но ваша программа тоже выдает неверные значения: у Вас s всегда равен вводимому n.
П.С. Все понял, прошу прощения. Последний раз редактировалось DsDevis; 24.03.2009 в 04:08. Причина: Посыпаю голову пеплом. |
24.03.2009, 04:04 | #4 |
Пользователь
Регистрация: 20.03.2009
Сообщений: 32
|
лучше делать через рекурсию.. мне так удобнее, например)
Код:
|
24.03.2009, 04:57 | #5 |
Пользователь
Регистрация: 21.03.2009
Сообщений: 35
|
До рекурсии я еще не дошел, я только 2 день паскаль изучаю
|
30.09.2010, 15:39 | #6 |
Новичок
Джуниор
Регистрация: 30.09.2010
Сообщений: 1
|
можно и без рекурсии)) просто в первых двух кодах действительно есть небольшие ошибки)) вот мой код)
program fact; var s,k,n: longint; {некоторые факториалы не умещаются в integer, а использовать real не вижу смысла} begin; k:=1; s:=1; readln(n); while k<=n do begin s:=s*k; k:=k+1; end; writeln(s); end. А если написать k<n, то следует сделать вот так: writeln(s*n); Когда k<n при n=6 например, цикл доходит до 5 и останавливается, и на 6 не умножает, так как неравентство строгое, поэтому нужно умножить на n при выводе)) вот)) |
30.09.2010, 16:34 | #7 |
C++, Java
Старожил
Регистрация: 10.04.2010
Сообщений: 2,665
|
Лучше вообще так:
Код:
|
01.10.2010, 10:01 | #8 |
Форумчанин
Регистрация: 23.09.2010
Сообщений: 682
|
А чем лучше? Если ещё учесть что не
Код:
Код:
Проще всего признать свою ошибку.
Гораздо труднее еЁ осознать и исправить. |
09.12.2010, 18:56 | #9 |
Форумчанин
Регистрация: 09.12.2010
Сообщений: 115
|
Код:
|
Похожие темы | ||||
Тема | Автор | Раздел | Ответов | Последнее сообщение |
вычисление выражений (pascal) | вкусняшка | Помощь студентам | 4 | 14.03.2009 16:42 |
Си, вычисление факториала | ManInBlack | Помощь студентам | 2 | 07.03.2009 00:50 |
вычисление X n-го порядка // delphi, pascal | JENqa | Помощь студентам | 2 | 26.12.2008 17:02 |
Pascal: Вычисление корна с помощью рекурсии. | MaGWaY_minsk | Помощь студентам | 2 | 11.11.2008 22:20 |
Вычисление факториала числа | PAVEL315 | Общие вопросы Delphi | 17 | 21.03.2007 07:32 |