Форум программистов, компьютерный форум, киберфорум
Lisp
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.83/6: Рейтинг темы: голосов - 6, средняя оценка - 4.83
0 / 0 / 0
Регистрация: 17.08.2017
Сообщений: 2

Program stack overflow ( простые числа)

22.01.2012, 21:09. Показов 1081. Ответов 4
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Задание : найти заданное количество простых чисел (начиная от 2)

Решение :
Code
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
(defun issimple (a b)
    (cond
        ((> b (/ a 2)) T)
        ((eq (mod a b) 0) Nil)
        (T (issimple a (+ b 1)))
    )
)
 
(defun subf (a b)
    (cond
        ((eq a 0) Nil)
        ((issimple b 2) (cons b (subf (- a 1) (+ b 1))))
        (T (subf a (+ b 1)))
    )
)
 
(defun fun (a)
    (subf a 2)
)
Проблема: программа отлично работает до ввода количества простых чисел = 341, если ввести больше ,то происходит Program stack oveflow
Помогите пожалуйста исправить данную ошибку, чтобы можно было вводить количество простых чисел 1000+

Пример ошибки :

0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
22.01.2012, 21:09
Ответы с готовыми решениями:

Как избежать Stack overflow?
Следующий код хорошо работает для вызовов от единицы и от двойки, но от тройки и четверки я получаю Stack overflow. Что можно сделать,...

Stack Overflow
происходит переполнение стека. можно ли его как-нибудь динамически присобачить? мб опция какая-нибудь в компиляторе есть.. или за 16кб...

Stack overflow.
У меня в программе есть реверсивная функция (много параметров) она вызывает себя очень много раз. Во время выполнения программы возникает...

4
defun
603 / 617 / 44
Регистрация: 30.04.2011
Сообщений: 702
22.01.2012, 23:58
Lisp
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
(defun f (num)
           (labels 
               ((iter (num x res)
                  (if (= res x) ()
                      (if 
                       (labels ((fun (num it)
                                  (if (or (= it 1)
                                          (= num 1)) t
                                          (if (zerop (mod num it)) ()
                                              (fun num (1- it))))))
                         (fun num (1- num)))
                       (cons num (iter (1+ num) x (1+ res)))
                       (iter (1+ num) x res)))))
             (iter 2 num 0)))
 
CL-USER> (f 35)
(2 3 5 7 11 13 17 19 23 29 31 37 41 43 47 53 59 61 67 71 73 79 83 89 97 101 103
 107 109 113 127 131 137 139 149)
Добавлено через 22 минуты
Lisp
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
CL-USER> (defun primep (num it)
           (if (or (= it 1)
                   (= num 1)) t
                   (unless (zerop (mod num it))
                     (primep num (1- it)))))
 
CL-USER> (defun coll-primep (num &optional (n 2) (x 0))
           (if (= x num) ()
               (if (primep n (1- n))
                   (cons n (coll-primep num (1+ n) (1+ x)))
                   (coll-primep num (1+ n) x))))
 
CL-USER> (coll-primep 35)
(2 3 5 7 11 13 17 19 23 29 31 37 41 43 47 53 59 61 67 71 73 79 83 89 97 101 103
 107 109 113 127 131 137 139 149)
Добавлено через 6 минут
надо 1000+
вот
results.zip

Добавлено через 19 минут
Lisp
1
2
3
4
5
6
7
8
9
10
11
12
(defun prime-collect (num)
           (flet ((primep (num)
                    (if (> num 1)
                        (loop for a from 2 to (isqrt num)
                           never (zerop (mod num a))))))
                  (flet ((next-prime (num)
                           (loop for a from num
                              when (primep a)
                              return a)))
                    (loop repeat num
                       for x = 2 then (next-prime (1+ x))
                       collect x))))
CL-USER> (time (coll-primep 2500))
Evaluation took:
8.498 seconds of real time
8.455364 seconds of total run time (8.452372 user, 0.002992 system)
99.49% CPU
20,344,695,456 processor cycles
65,664 bytes consed

CL-USER> (time (f 2500))
Evaluation took:
10.779 seconds of real time
10.723192 seconds of total run time (10.718305 user, 0.004887 system)
99.48% CPU
25,806,179,672 processor cycles
98,560 bytes consed

CL-USER> (time (prime-collect 2500))
Evaluation took:
0.025 seconds of real time
0.024933 seconds of total run time (0.024933 user, 0.000000 system)
100.00% CPU
59,954,754 processor cycles
1,867,296 bytes consed

CL-USER> (time (prime-collect 100000))
Evaluation took:
3.558 seconds of real time
3.540322 seconds of total run time (3.513195 user, 0.027127 system)
[ Run times consist of 0.083 seconds GC time, and 3.458 seconds non-GC time. ]
99.49% CPU
8,517,446,682 processor cycles
145,205,840 bytes consed
0
0 / 0 / 0
Регистрация: 17.08.2017
Сообщений: 2
23.01.2012, 00:17
хм странно у меня и при этом варианте
Lisp
1
2
3
4
5
6
7
8
9
10
11
12
13
14
(defun f (num)
           (labels 
               ((iter (num x res)
                  (if (= res x) ()
                      (if 
                       (labels ((fun (num it)
                                  (if (or (= it 1)
                                          (= num 1)) t
                                          (if (zerop (mod num it)) ()
                                              (fun num (1- it))))))
                         (fun num (1- num)))
                       (cons num (iter (1+ num) x (1+ res)))
                       (iter (1+ num) x res)))))
             (iter 2 num 0)))
и при этом
Lisp
1
2
3
4
5
6
7
8
9
10
11
(defun primep (num it)
           (if (or (= it 1)
                   (= num 1)) t
                   (unless (zerop (mod num it))
                     (primep num (1- it)))))
 
(defun coll-primep (num &optional (n 2) (x 0))
           (if (= x num) ()
               (if (primep n (1- n))
                   (cons n (coll-primep num (1+ n) (1+ x)))
                   (coll-primep num (1+ n) x))))
все равно переполнение стека идет или я что то не правильно понял (что более вероятно) илт что то не правильно делаю ( что еще более вероятно)
0
Эксперт С++
 Аватар для Nameless One
5828 / 3479 / 358
Регистрация: 08.02.2010
Сообщений: 7,448
23.01.2012, 05:12

Не по теме:

Цитата Сообщение от transformator.t Посмотреть сообщение
почему тут нет спойлера??
тег [SPOILER='caption']text[/SPOILER]



Цитата Сообщение от NiMdis Посмотреть сообщение
все равно переполнение стека идет или я что то не правильно понял (что более вероятно) илт что то не правильно делаю ( что еще более вероятно)
скорее всего, твоя реализация не поддерживает TCO. Перепиши через цикл
0
defun
603 / 617 / 44
Регистрация: 30.04.2011
Сообщений: 702
23.01.2012, 15:17
Nameless One, благодарю)
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
23.01.2012, 15:17
Помогаю со студенческими работами здесь

stack overflow
Всем привет. пишу void test() { try { cout << "test \n"; test(); } catch(exception e) {

Stack overflow
Еще раз здрасьте=) Простите за дубляж тем, но последние сообщения тут, видимо, читают редко, а мне срочно нужна эта программка. Кстати,...

Stack overflow
Реализовал структуру данных стек на связном списке, очистку решил возложить на деструкторы узлов, т.е. каждый вызов деструктора узла...

Stack overflow
Написал #include "stdafx.h" #include <iostream> using namespace std; #include <math.h> #include <iomanip> #include...

Stack overflow!
Привет всем! если кто знает, как побороть ошибку "stack overflow"? пишу: procedure TDataModule1.cdsPrihSlaveCalcFields(DataSet:...


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

Или воспользуйтесь поиском по форуму:
5
Ответ Создать тему
Новые блоги и статьи
http://iceja.net/ математические сервисы
iceja 20.01.2026
Обновила свой сайт http:/ / iceja. net/ , приделала Fast Fourier Transform экстраполяцию сигналов. Однако предсказывает далеко не каждый сигнал (см ограничения http:/ / iceja. net/ fourier/ docs ). Также. . .
http://iceja.net/ сервер решения полиномов
iceja 18.01.2026
Выкатила http:/ / iceja. net/ сервер решения полиномов (находит действительные корни полиномов методом Штурма). На сайте документация по API, но скажу прямо VPS слабенький и 200 000 полиномов. . .
Расчёт переходных процессов в цепи постоянного тока
igorrr37 16.01.2026
/ * Дана цепь постоянного тока с R, L, C, k(ключ), U, E, J. Программа составляет систему уравнений по 1 и 2 законам Кирхгофа, решает её и находит переходные токи и напряжения на элементах схемы. . . .
Восстановить юзерскрипты Greasemonkey из бэкапа браузера
damix 15.01.2026
Если восстановить из бэкапа профиль Firefox после переустановки винды, то список юзерскриптов в Greasemonkey будет пустым. Но восстановить их можно так. Для этого понадобится консольная утилита. . .
Сукцессия микоризы: основная теория в виде двух уравнений.
anaschu 11.01.2026
https:/ / rutube. ru/ video/ 7a537f578d808e67a3c6fd818a44a5c4/
WordPad для Windows 11
Jel 10.01.2026
WordPad для Windows 11 — это приложение, которое восстанавливает классический текстовый редактор WordPad в операционной системе Windows 11. После того как Microsoft исключила WordPad из. . .
Classic Notepad for Windows 11
Jel 10.01.2026
Old Classic Notepad for Windows 11 Приложение для Windows 11, позволяющее пользователям вернуть классическую версию текстового редактора «Блокнот» из Windows 10. Программа предоставляет более. . .
Почему дизайн решает?
Neotwalker 09.01.2026
В современном мире, где конкуренция за внимание потребителя достигла пика, дизайн становится мощным инструментом для успеха бренда. Это не просто красивый внешний вид продукта или сайта — это. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru