前提・実現したいこと
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 ループに入る前にセグメントツリーの各要素を配列に一時保存した値に従って更新する、という方法でないと正しく動作しないのではないかと思ってしまいます。
セグメントツリーの更新を上記コードのようにしてしまっても問題ない理由について、何かお分かりの方がいらっしゃったらお助けいただけないでしょうか。
回答1件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
2020/12/25 10:23