質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.50%
C++

C++はC言語をもとにしてつくられた最もよく使われるマルチパラダイムプログラミング言語の1つです。オブジェクト指向、ジェネリック、命令型など広く対応しており、多目的に使用されています。

Q&A

1回答

327閲覧

C++ セグメンテーションフォルト

metal3000

総合スコア12

C++

C++はC言語をもとにしてつくられた最もよく使われるマルチパラダイムプログラミング言語の1つです。オブジェクト指向、ジェネリック、命令型など広く対応しており、多目的に使用されています。

0グッド

0クリップ

投稿2019/05/18 17:45

前提・実現したいこと

C++のSegmentation Faultのデバッグ

発生している問題・エラーメッセージ

Segmentation fault: 11

該当のソースコード

#include<iostream> #include<stack> #include<algorithm> #include<string> #include<vector> using namespace std; int main(){ stack<int> S1; stack<pair<int,int> > S2; int sum = 0; char temp; int counter = 1; while(1){ cin >> temp; if(temp == '\') S1.push(counter); else if(temp == '/'){ int j = S1.top(); S1.pop(); sum += counter-j; int a = counter-j; while(S2.top().first > j && S2.size() > 0){ a += S2.top().second; S2.pop(); } S2.push(make_pair(j,a)); }else if(temp == 'q'){ break; } counter += 1; } vector<int> ans; while(S2.size()>0){ ans.push_back(S2.top().second); S2.pop(); } cout << sum << endl; cout << ans.size() << endl; for(int i=0;i<ans.size();i++){ cout << " " <<ans[i]; } return 0; }

試したこと

while(1)内のelse ifに差し掛かったところでSegmentation Faultが出ているようなのですが、それ以上分からず、大変お手数ですがどなたかお助け下さい。

補足情報(FW/ツールのバージョンなど)

ここにより詳細な情報を記載してください。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

stackが空の状態でint j = S1.top();を実行するとSegmentation Faultになりますよ。
あと、while(S2.top().first > j && S2.size() > 0)はsize判定が先d^^

投稿2019/05/18 18:36

cateye

総合スコア6851

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだベストアンサーが選ばれていません

会員登録して回答してみよう

アカウントをお持ちの方は

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.50%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問