🎄teratailクリスマスプレゼントキャンペーン2024🎄』開催中!

\teratail特別グッズやAmazonギフトカード最大2,000円分が当たる!/

詳細はこちら
アルゴリズム

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

C++

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

Q&A

解決済

1回答

661閲覧

yukicoder No.1117 数列分割 のセグメントツリーを用いた解法について

shukrin

総合スコア14

アルゴリズム

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

C++

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

0グッド

0クリップ

投稿2020/12/24 11:06

前提・実現したいこと

yukicoder No.1117 数列分割 のセグメントツリーを用いた解法について、わからない箇所があり質問させていただきました。何かお分かりになられる方がいらっしゃいましたら、お助けいただけますと幸いです。

発生している問題

上記問題について、セグメントツリーを用いた解法があるようなのですが、セグメントツリーの更新について理解できていない箇所がございます。以下、上記コードからセグメントツリーの更新部分のみを抜粋したものとなります。

C++

1for (int j = 0; j < k; j++) { 2 for (int i = n - 1; i >= 0; i--) { 3 dp[j + 1][i + 1] = max(dp[j + 1][i + 1], seg1.get_query(i + 1 - m, i + 1) + sum[i + 1]); 4 dp[j + 1][i + 1] = max(dp[j + 1][i + 1], seg2.get_query(i + 1 - m, i + 1) - sum[i + 1]); 5 seg1.update_query(i + 1, dp[j + 1][i + 1] - sum[i + 1]); 6 seg2.update_query(i + 1, dp[j + 1][i + 1] + sum[i + 1]); 7 } 8 }

提出者様の解説

自分が疑問に思っていることは、ある i についてセグメントツリーの i 番目の要素の更新が終わった後 i + 1 番目の要素を更新する際、今さっき更新した i 番目の要素も区間に含んでしまっているため正しく更新することができないのではないかということです。

自分の感覚としては、j ループ目の更新を行う際は、ある i について更新された後の dp の値をいったん別の配列等に保存し、すべての i について dp の値を求め終わった後、次の j + 1 ループに入る前にセグメントツリーの各要素を配列に一時保存した値に従って更新する、という方法でないと正しく動作しないのではないかと思ってしまいます。

セグメントツリーの更新を上記コードのようにしてしまっても問題ない理由について、何かお分かりの方がいらっしゃったらお助けいただけないでしょうか。

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

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

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

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

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

guest

回答1

0

ベストアンサー

ある i についてセグメントツリーの i 番目の要素の更新が終わった後 i + 1 番目の要素を更新する際

iはデクリメントされてるのでi + 1番目の更新はi番目の更新の前に終わっています

投稿2020/12/24 12:10

yudedako67

総合スコア2047

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

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

shukrin

2020/12/25 10:23

ご回答ありがとうございます。とても助かりました。以降はもっと注意深くコードを読むよう心がけようと思います。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.36%

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

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

質問する

関連した質問