Форум программистов, компьютерный форум, киберфорум
PascalABC.NET
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.95/75: Рейтинг темы: голосов - 75, средняя оценка - 4.95
0 / 0 / 0
Регистрация: 15.02.2014
Сообщений: 17

"Программа завершена из-за переполнения программного стека" при работе рекурсивной функции

07.12.2014, 19:59. Показов 15241. Ответов 5
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Здравствуйте

Задание:Вычислить рекурсивно функцию вида у=COS(X)+COS(X^2)+COS(X^3)+...+COS( X^N)

Ошибка:Ошибка времени выполнения: StackOverflowException: Программа завершена из-за переполнения программного стека

Объясните пожалуйста почему происходит такая ошибка

Вот код:
Pascal
1
2
3
4
5
6
7
8
9
10
11
12
var
y:integer;
function cosinus(x:integer):integer;
begin
if x=1 then cosinus:=cosinus(x)
else
cosinus:=cosinus(x)+cosinus(x*x);
end;
begin
readln(y);
write(cosinus(y));
end.
0
Лучшие ответы (1)
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
07.12.2014, 19:59
Ответы с готовыми решениями:

Программа завершена из-за переполнения программного стека
В общем задача найти сумму 1/1!+1/2!+...+1/n! при n>10 Программу написал, все процедуры проверил, по отдельности работают, а когда...

Программа завершена из-за переполнения программного стека
Писал метод быстрой сортировки и выскакивает данная проблема "Ошибка времени выполнения: StackOverflowException: Программа завершена из-за...

Ошибка времени выполнения: StackOverflowException: Программа завершена из-за переполнения программного стека
program a1; var s:integer; k:longint; procedure f(n:longint); begin if (0<=n) and (n<=1000000000) then begin ...

5
Супер-модератор
Эксперт Pascal/DelphiАвтор FAQ
 Аватар для volvo
33399 / 21509 / 8236
Регистрация: 22.10.2011
Сообщений: 36,907
Записей в блоге: 12
08.12.2014, 15:42
Потому что у тебя нет выхода из рекурсии. Независимо от значения аргумента, все равно рекурсивно вызывается эта же функция. Лучше бы привел формулу, по которой происходит вычисление...
1
0 / 0 / 0
Регистрация: 15.02.2014
Сообщений: 17
08.12.2014, 19:34  [ТС]
Подскажите пожалуйста как правильно выйти из рекурсии
0
Супер-модератор
Эксперт Pascal/DelphiАвтор FAQ
 Аватар для volvo
33399 / 21509 / 8236
Регистрация: 22.10.2011
Сообщений: 36,907
Записей в блоге: 12
08.12.2014, 19:36
Для этого надо как минимум знать, что вообще надо подсчитать
0
0 / 0 / 0
Регистрация: 15.02.2014
Сообщений: 17
08.12.2014, 19:48  [ТС]
Задание:
Вычислить рекурсивно функцию вида у=COS(X)+COS(X^2)+COS(X^3)+...+COS( X^N)
0
Супер-модератор
Эксперт Pascal/DelphiАвтор FAQ
 Аватар для volvo
33399 / 21509 / 8236
Регистрация: 22.10.2011
Сообщений: 36,907
Записей в блоге: 12
08.12.2014, 20:02
Лучший ответ Сообщение было отмечено marat687 как решение

Решение

Pascal
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
var 
  xvalue : real;
  
function func(x : real; n : integer) : real;
begin
  if n = 0 then result := 0 // Вот условие выхода
  else result := cos(x) + func(x * xvalue, n - 1);
end;
 
var n : integer;
begin
  write('x = '); readln(xvalue);
  write('n = '); readln(n);
  
  writeln(func(xvalue, n));
end.
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
08.12.2014, 20:02
Помогаю со студенческими работами здесь

Ошибка времени выполнения: StackOverflowException: Программа завершена из-за переполнения программного стека
Помогите пожалуйста исправить!!! Писал простенький тригонометрический калькулятор. Я так понимаю ошибка из-за рекурсии в модуле, но я не...

Ошибка времени выполнения: StackOverflowException: Программа завершена из-за переполнения программного стека
Программа должна создавать массив из квадратов со стороной в 5 пикселей и случайного цвета (координаты верхней левой точки рандомные, если...

Ошибка времени выполнения: StackOverflowException: Программа завершена из-за переполнения программного стека
var A:array of integer; i,g,code,k,m,t,o,n:integer; st:string; procedure krut(m:integer); var g,g1:integer; begin If m>0...

Ошибка времени выполнения: StackOverflowException: Программа завершена из-за переполнения программного стека
Function F(n:integer):integer; begin for n:=1 to 1000 do begin if n<=15 then F:= 2*n*n + 4*n + 3 else ...

Ошибка времени выполнения: StackOverflowException: Программа завершена из-за переполнения программного стека
здравствуйте. Выходит ошибка "Ошибка времени выполнения: StackOverflowException: Программа завершена из-за переполнения программного...


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

Или воспользуйтесь поиском по форуму:
6
Ответ Создать тему
Новые блоги и статьи
Оттенки серого
Argus19 18.03.2026
Оттенки серого Нашёл в интернете 3 прекрасных модуля: Модуль класса открытия диалога открытия/ сохранения файла на Win32 API; Модуль класса быстрого перекодирования цветного изображения в оттенки. . .
SDL3 для Desktop (MinGW): Рисуем цветные прямоугольники с помощью рисовальщика SDL3 на Си и C++
8Observer8 17.03.2026
Содержание блога Финальные проекты на Си и на C++: finish-rectangles-sdl3-c. zip finish-rectangles-sdl3-cpp. zip
Символические и жёсткие ссылки в Linux.
algri14 15.03.2026
Существует два типа ссылок — символические и жёсткие. Ссылка в Linux — это запись в каталоге, которая может указывать либо на inode «файла-ИСТОЧНИКА», тогда это будет «жёсткая ссылка» (hard link),. . .
[Owen Logic] Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора
ФедосеевПавел 14.03.2026
Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора ВВЕДЕНИЕ Выполняя задание на управление насосной группой заполнения резервуара,. . .
делаю науч статью по влиянию грибов на сукцессию
anaschu 13.03.2026
прикрепляю статью
SDL3 для Desktop (MinGW): Создаём пустое окно с нуля для 2D-графики на SDL3, Си и C++
8Observer8 10.03.2026
Содержание блога Финальные проекты на Си и на C++: hello-sdl3-c. zip hello-sdl3-cpp. zip Результат:
Установка CMake и MinGW 13.1 для сборки С и C++ приложений из консоли и из Qt Creator в EXE
8Observer8 10.03.2026
Содержание блога MinGW - это коллекция инструментов для сборки приложений в EXE. CMake - это система сборки приложений. Здесь описаны базовые шаги для старта программирования с помощью CMake и. . .
Как дизайн сайта влияет на конверсию: 7 решений, которые реально повышают заявки
Neotwalker 08.03.2026
Многие до сих пор воспринимают дизайн сайта как “красивую оболочку”. На практике всё иначе: дизайн напрямую влияет на то, оставит человек заявку или уйдёт через несколько секунд. Даже если у вас. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru