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

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

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

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

C++

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

Q&A

解決済

1回答

1083閲覧

AtCoder Beginner Contest 188E Peddler TLEになってしまう

encho

総合スコア182

アルゴリズム

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

C++

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

0グッド

0クリップ

投稿2021/08/13 04:58

編集2021/08/13 05:00

#AtCoder Beginner Contest 188E Peddler TLEになってしまう
ABC188E
こちらの問題を解いていましたが自分の実装ではTLEになってしまうため、どなたかアドバイスを頂けると幸いです。

問題文

問題

質問内容

非連結のグラフなので0~nでループを回してdfsをしています。
更新済みの場合はskipをしています。

概ねのテストケースは通っていますがいくつかTLEになっています。
O(N+M)の実装だと思っていたのですがTLEになってしまうため、アドバイスをいただきたいです。

実装

C++

1#include <bits/stdc++.h> 2using namespace std; 3using ll = long long; 4const long long INF = 1LL << 60; 5 6int n, m; 7vector<ll> a; 8vector<vector<int>> g; 9vector<ll> dp; 10 11// 深さ優先探索 12void dfs(int v) { 13 for(auto nv:g[v]) { 14 dp[nv] = min(dp[nv], min(dp[v], a[v])); 15 dfs(nv); 16 } 17} 18 19int main() { 20 cin >> n >> m; 21 a.resize(n); 22 g.resize(n); 23 dp.resize(n, INF); 24 for(int i=0; i<n; i++) cin >> a[i]; 25 for(int i=0; i<m; i++) { 26 int x, y; 27 cin >> x >> y; 28 x--; y--; 29 g[x].push_back(y); 30 } 31 32 for(int i=0; i<n; i++) { 33 if(dp[i] != INF) continue; 34 dfs(i); 35 } 36 ll res = -INF; 37 for(int i=0; i<n; i++) { 38 res = max(res, a[i]-dp[i]); 39 } 40 cout << res << endl; 41}

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

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

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

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

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

guest

回答1

0

ベストアンサー

ある町から別のある街に至るルートが複数あり、それらが連結している場合に計算量が爆発します。

text

15 6 21 1 1 1 1 31 2 41 3 52 3 63 4 73 5 84 5

1から3に至るルートが1→2→3と1→3の2通り、3から5に至るルートが3→4→5と3→5の2通りあります。
これを深さ優先探索すると、3から5に至る2通りのルートが2重に探索されるのが分かるでしょうか。

同様に、5の後ろに2通りのルートを1つ連結するごとに、探索回数が倍々に増えていくことになります。

投稿2021/08/13 11:38

編集2021/08/13 12:04
actorbug

総合スコア2429

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

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

encho

2021/08/13 12:17 編集

ありがとうございます。理解できました。 dfsの計算量がO(V+E)となっていますが、一度探索したものはもう通ることはないという前提ですね。
actorbug

2021/08/13 13:05 編集

コメントからすると、dfsで処理済みの道or町をスキップしようとしているように聞こえるのですが、それだとTLEではなくなるもののWAになってしまうと思われます。解説の解法1を実装するであれば、dfsにすること自体が誤りです。
encho

2021/08/13 22:59

そうですね! ご解説ありがとうございました!
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問