IPB
ЛогинПароль:

> Прочтите прежде чем задавать вопрос!

1. Заголовок темы должен быть информативным. В противном случае тема удаляется ...
2. Все тексты программ должны помещаться в теги [code=pas] ... [/code].
3. Прежде чем задавать вопрос, см. "FAQ", если там не нашли ответа, воспользуйтесь ПОИСКОМ, возможно такую задачу уже решали!
4. Не предлагайте свои решения на других языках, кроме Паскаля (исключение - только с согласия модератора).
5. НЕ используйте форум для личного общения, все что не относится к обсуждению темы - на PM!
6. Одна тема - один вопрос (задача)
7. Проверяйте программы перед тем, как разместить их на форуме!!!
8. Спрашивайте и отвечайте четко и по существу!!!

> Вычисление факториала, программа должна сообщать о переполнении
Евгений
сообщение 27.11.2010 20:11
Сообщение #1


Новичок
*

Группа: Пользователи
Сообщений: 36
Пол: Мужской
Реальное имя: Евгений

Репутация: -  0  +


Здравствуйте!
Дана задача по вычислению факториала, с которой вроде справился, но есть ограничения: "тип обработанных данных-longint, если результат не помещается в 4 байта программа должна сообщить об этом"
Вот что написал:
Program Factoreal;
uses crt;
var
N: longint;
M,I: integer;
Begin
clrscr;
N:=1;
write('введите число>=0 ');
readln(M);
if M=0 then N:=1
else
for I:=1 to M do
N:=N*I;
writeln ('Факториал равен:',' ',N);
readln;
end.


Как добиться того чтобы программа сообщала о переполнении? Перепобовал многое, но в итоге только еще больше запутался.
Может есть у кого какие идеи?

Сообщение отредактировано: Евгений - 27.11.2010 20:44
 Оффлайн  Профиль  PM 
 К началу страницы 
+ Ответить 
 
 Ответить  Открыть новую тему 
Ответов
volvo
сообщение 30.11.2010 9:28
Сообщение #2


Гость






Кстати, способ, который работает в любом компиляторе:
var
res: real;
N: longint;
M, I: integer;
Begin
N:=1;
write('M [ >= 0 ] = '); readln(M);
if M = 0 then N := 1
else
for I := 1 to M do
begin
res := 1.0 * N * I;
if res > maxlongint then
begin
writeln('error: overflow'); halt;
end
else n := trunc(res);
end;
writeln ('M! = ', N);
readln;
end.
 К началу страницы 
+ Ответить 
Lapp
сообщение 30.11.2010 9:48
Сообщение #3


Уникум
*******

Группа: Модераторы
Сообщений: 6 823
Пол: Мужской
Реальное имя: Лопáрь (Андрей)

Репутация: -  159  +


Цитата(volvo @ 30.11.2010 9:28) *
Кстати, способ, который работает в любом компиляторе:
var
res: real;
N: longint;
M, I: integer;
Begin
N:=1;
write('M [ >= 0 ] = '); readln(M);
if M = 0 then N := 1
else
for I := 1 to M do
begin
res := 1.0 * N * I;
if res > maxlongint then
begin
writeln('error: overflow'); halt;
end
else n := trunc(res);
end;
writeln ('M! = ', N);
readln;
end.

Тут есть небольшая неопределенность (которая вряд ли где приведет к ошибке, впрочем), следующая из неопределенности длины мантиссы. Для пущей уверенности лучше использовать double или extended..
Но если уж использовать maxlongint (и, собсно, почему бы нет? оно, наверное, есть везде..)), то тогда лучше уж сделать так, мне кажется (без действительных типов):
var
N: longint;
M,I: integer;
Overflow: boolean;

Begin
N:=1;
write('введите неотрицательное число: ');
readln(M);
N:=1;
i:=1;
while not Overflow and (i<=M) do begin
Overflow:= N > maxlongint div i;
if not Overflow then N:=N*I;
Inc(i)
end;
if Overflow then WriteLn('Overflow')
else writeln (M,'! = ',N);
readln;
end.


--------------------
я - ветер, я северный холодный ветер
я час расставанья, я год возвращенья домой
 Оффлайн  Профиль  PM 
 К началу страницы 
+ Ответить 

Сообщений в этой теме


 Ответить  Открыть новую тему 
1 чел. читают эту тему (гостей: 1, скрытых пользователей: 0)
Пользователей: 0

 



- Текстовая версия 24.06.2025 8:55
Хостинг предоставлен компанией "Веб Сервис Центр" при поддержке компании "ДокЛаб"