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

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

新規登録して質問してみよう
ただいま回答率
85.48%
アルゴリズム

アルゴリズムとは、定められた目的を達成するために、プログラムの理論的な動作を定義するものです。

Q&A

解決済

1回答

730閲覧

AtCoder ARC 37 バウムテスト ACできない理由がわからない

taiyaki29

総合スコア7

アルゴリズム

アルゴリズムとは、定められた目的を達成するために、プログラムの理論的な動作を定義するものです。

0グッド

0クリップ

投稿2020/02/12 16:52

前提・実現したいこと

AtCoder ARC 37 バウムテスト
https://atcoder.jp/contests/arc037/tasks/arc037_b
の問題がACできない。サンプルはすべてACし、自分で考えられるものをテストしても予想通りの結果が出る。

該当のソースコード

#include <bits/stdc++.h>
using namespace std;

bool loop = false;
void dfs(vector<vector<int>> A, int now, int before, vector<int> &vi){

if(vi[now]==1){loop=true;return;}
vi[now]=1;
for(int i=0; i<A[now].size(); i++){
if(before == A[now][i])continue; //直前は飛ばす
before = now;
now = A[now][i];
dfs(A,now,before,vi);
return;
}
}

int main() {

int N,M,ans=0; cin>>N>>M; vector<vector<int>> A(1000,vector<int>(0)); //入力を受け取って配列にする vector<int> vi(1000,0); //visitedの管理 for(int j=0; j<M; j++){ int p=0,c=0; cin>>p>>c;p--;c--; A[p].push_back(c); A[c].push_back(p); } for(int k=0; k<N;k++){ if(vi[k]==1)continue; dfs(A,k,-1,vi); if(!loop)ans++; loop=false; }

cout<<ans<<endl;
}

試したこと

例題、と自分で思いついたもの何個か

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

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

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

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

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

guest

回答1

0

ベストアンサー

Text

14 4 21 2 31 3 41 4 53 4

このようなテストケースはどうでしょう
明らかに閉路を持つ連結成分しか存在しませんが、そのプログラムは「1」を表示します。

投稿2020/02/12 17:12

yudedako67

総合スコア2047

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

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

taiyaki29

2020/02/13 04:48

ありがとうございます。おかしいところに気づけました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問