https://atcoder.jp/contests/arc037/tasks/arc037_b
にある問題を解こうとしたのですが、以下のコードを実行するとsegmentation faultになりました。原因がわからないので教えていただきたいです。
c++
1#include <bits/stdc++.h> 2using namespace std; 3using graph=vector<vector<int>>; 4typedef long long ll; 5typedef long double ld; 6typedef pair<int, int> P; 7const ll mod = 1000000007; 8const ll INF = 1e+14; 9#define rep(i,n) for(int i=0;i<n;i++) 10#define per(i,n) for(int i=n-1;i>=0;i--) 11#define Rep(i,sta,n) for(int i=sta;i<n;i++) 12#define rep1(i,n) for(int i=1;i<=n;i++) 13#define per1(i,n) for(int i=n;i>=1;i--) 14#define Rep1(i,sta,n) for(int i=sta;i<=n;i++) 15#define _GLIBCXX_DEBUG 16 17bool seen[110]={false}; 18 19bool dfs(graph &G , int v){ 20 bool judge=true; 21 seen[v]=true; 22 int count=0; 23 //vから行ける頂点 24 for(auto next_v: G[v]){ 25 if(seen[next_v]){ 26 count++; 27 if(count>=2) judge=false; 28 continue; 29 } 30 dfs(G,next_v); 31 } 32 return judge; 33} 34 35int main(){ 36 int n,m; cin>>n>>m; 37 graph G; 38 //グラフ受け取り 39 rep(i,m){ 40 int a,b; 41 cin>>a>>b; 42 G[a].push_back(b); 43 G[b].push_back(a); 44 } 45 int ans=0; 46 rep1(i,n){ 47 if(seen[i]) continue; 48 else { 49 if(dfs(G,i)) ans++; 50 } 51 } 52 cout<<ans<<endl; 53}
回答1件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。