Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.63/8: Рейтинг темы: голосов - 8, средняя оценка - 4.63
0 / 0 / 0
Регистрация: 21.05.2017
Сообщений: 14

Segmentation fault при работе со стеком

31.05.2017, 17:50. Показов 1716. Ответов 10
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Господа, если не затруднит, помогите пожалуйста с этой проблемой:
Код компилируется, запускается -- и сразу аварийно завершает работу. Дебаггер сразу при запуске выдает ошибку "SIGSEGV, Segmentation fault", ссылаясь в Call Stack на начало функции main. Судя по описанию ошибки из Википедии, я как то неверно выделяю память? Вот и сам код, собственно говоря:
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
#include<iostream>
#include<string>
#include<stack>
using namespace std;
 
const int maxn = 500000;
 
 
int main()
{
    int n,m,p, l[maxn],r[maxn],po[maxn];
    char line[maxn],commands[maxn];
 
    cin >> n >> m >> p >> line >> commands;
    stack<int> st;
    for(int i=1;i<=n;i++)
    {
        if(line[i-1]=='(') st.push(i);
        else
        {
            po[st.top()] = i;
            po[i]=st.top();
            st.pop();
        }
    }
    for(int i=0;i<=n;++i)
    {
        l[i]=i-1;
        r[i]=i+1;
    }
    for(int i=0;i<m;++i)
    {
        if(commands[i]=='R') p=r[p];
        else if(commands[i]=='L') p=l[p];
        else
        {
            if(p>po[p]) p=po[p];
            int ll = l[p],rr=r[po[p]];
            r[ll]=rr;
            l[rr]=ll;
            p=rr;
            if(p==n+1) p=ll;
        }
    }
    for(int i=r[0];i<=n;i=r[i])
        cout << line[i-1];
    cout << endl;
    return 0;
}
Добавлено через 4 минуты
Каюсь, понял в чем ошибка. Указал в качестве размера массивов неинициализированную переменную. Тему можно закрывать
0
Лучшие ответы (1)
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
31.05.2017, 17:50
Ответы с готовыми решениями:

Segmentation fault при наследовании класса
Доброго времени суток! Имею класс Initialise и класс Environment. В первом создаются экземпляры движка и прочие сопутствующие вещи....

Segmentation fault при вызове метода
Собственно такое дело, имеется следующий код: Item* m_items; Player::Player() { ... memset(m_items, 0,...

Segmentation fault при использовании модуля <time.h>
Есть код time_t now; struct tm * ptr; static char tbuf; bzero(tbuf,64); time(&amp;now); ptr = localtime(&amp;now); strftime(tbuf, 64,...

10
nd2
3438 / 2817 / 1249
Регистрация: 29.01.2016
Сообщений: 9,427
31.05.2017, 18:52
Лучший ответ Сообщение было отмечено kindOfAnonimous как решение

Решение

Цитата Сообщение от kindOfAnonimous Посмотреть сообщение
Указал в качестве размера массивов неинициализированную переменную.
Это где? Всё инициализировано:
Цитата Сообщение от kindOfAnonimous Посмотреть сообщение
C++
1
const int maxn = 500000;
Размера стека не хватает под массивы.
1
зомбяк
 Аватар для TRam_
1585 / 1219 / 345
Регистрация: 14.05.2017
Сообщений: 3,940
31.05.2017, 19:45
nd2, видимо ранее цифры 500000 там небыло .
1
nd2
3438 / 2817 / 1249
Регистрация: 29.01.2016
Сообщений: 9,427
31.05.2017, 19:48
Цитата Сообщение от TRam_ Посмотреть сообщение
видимо ранее цифры 500000 там небыло
Может быть, но всё равно стека не должно хватить.
1
0 / 0 / 0
Регистрация: 21.05.2017
Сообщений: 14
31.05.2017, 20:34  [ТС]
Этим выражением я по сути процитировал Википедию, думаю, как раз неправильная формулировка (Ох уж эти редакторы википедии). Исправил все заменив все упоминания переменной maxn в объявлении массивов на вручную заданное число -- 500000
0
nd2
3438 / 2817 / 1249
Регистрация: 29.01.2016
Сообщений: 9,427
31.05.2017, 20:48
Цитата Сообщение от kindOfAnonimous Посмотреть сообщение
Исправил все заменив все упоминания переменной maxn в объявлении массивов на вручную заданное число -- 500000
И что, работает?

Добавлено через 9 минут
Цитата Сообщение от TRam_ Посмотреть сообщение
видимо ранее цифры 500000 там небыло
Тогда бы не скомпилировалось, const же.
0
0 / 0 / 0
Регистрация: 21.05.2017
Сообщений: 14
01.06.2017, 15:33  [ТС]
nd2, Да, сам удивлен, но это сработало. Притом больше ничего не делал, только это исправление.
0
nd2
3438 / 2817 / 1249
Регистрация: 29.01.2016
Сообщений: 9,427
01.06.2017, 15:49
Среда какая? ОС?
1
0 / 0 / 0
Регистрация: 21.05.2017
Сообщений: 14
02.06.2017, 18:30  [ТС]
Windows 10, Code::Blocks
0
nd2
3438 / 2817 / 1249
Регистрация: 29.01.2016
Сообщений: 9,427
02.06.2017, 18:35
Цитата Сообщение от kindOfAnonimous Посмотреть сообщение
Windows 10, Code::Blocks
И как рабочий код сейчас выглядит?
1
0 / 0 / 0
Регистрация: 21.05.2017
Сообщений: 14
02.06.2017, 18:56  [ТС]
Сразу скажу: Каюсь, Вы были совершенно правы, суть не в инициализации, а в размере константы. Я опечатался и ввел 50000 вместо 500000. При исправлении опечатки код не работает.
Не подскажете, где можно узнать об ограничении памяти динамических структур?
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
02.06.2017, 18:56
Помогаю со студенческими работами здесь

Ошибка выполнения Segmentation fault при открытии файла
Привет всем! почему не открывается файл, не понимаю что такое? ubuntu 16, qt creator 3.6.1 #include &lt;string&gt; #include...

C++ ошибка кода Segmentation fault при динамической памяти
помогите пожалуйста. задание такое: нужна программа которая хранит название страны с медалями и может добавлять новые страны, а если имя...

При вводе данных в программу выходит ошибка Segmentation fault
В чем может быть ошибка? Заранее спасибо! #include &lt;iostream&gt; #include &lt;string&gt; using namespace std; class MARSH { public:...

Ошибка "Segmentation fault" при организации дерева
Есть следующие функции Three сreateThree(Node **q) { if((*q)-&gt;p) { Three *one, *two; one =...

[C/C++] "Segmentation fault" при попытке передачи параметра командной строки.
Прога вылетает при попытке передачи параметра через командную строку.Такой код: #include &lt;iostream&gt; #include &lt;cstring&gt; ...


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

Или воспользуйтесь поиском по форуму:
11
Ответ Создать тему
Новые блоги и статьи
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Как объединить две одинаковые БД Access с разными данными
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
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 . Быстренько разберем подход "на фреймах". Мы делаем одну. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru