最小部分列問題 「 競プロ典型 90 問」の 006 - Smallest Subsequence(★5) (最少部分列問題) という問題を解いてみたのですが、最初は解説をみてもさっぱり分からず打ちひしがれていました・・・。 が、けんちょんの競プロ精進記録 を見るに、どうもこの問題を解く途中で出てくる nex という配列が「極めて汎用性が高いので、実にさまざまな問題で活用できます!!!」ということらしく、ちゃんと理解しといた方が良さそうだ・・・ということで気を取り直して取り組んでみたところなんとか理解できました。 せっかくなので忘れないうちに解説記事を作って記憶を定着させたいと思います。なお後半の実装パートは、Haskell で実装します。 けんちょんさんの解説記事にあるとおり、この問題 (を全探索で解く場合) の解法のキーになるのは事前に「任意の文字が i 番目以降に出現する位置」を二次
![「競プロ典型 90問」Smallest Subsequence (最小部分列問題)](https://cdn-ak-scissors.b.st-hatena.com/image/square/91518faf66120004ce2d0edce3b987ab2e154fbd/height=288;version=1;width=512/https%3A%2F%2Fres.cloudinary.com%2Fzenn%2Fimage%2Fupload%2Fs--kZo7GiAz--%2Fc_fit%252Cg_north_west%252Cl_text%3Anotosansjp-medium.otf_55%3A%2525E3%252580%25258C%2525E7%2525AB%2525B6%2525E3%252583%252597%2525E3%252583%2525AD%2525E5%252585%2525B8%2525E5%25259E%25258B%25252090%2525E5%252595%25258F%2525E3%252580%25258DSmallest%252520Subsequence%252520%252528%2525E6%25259C%252580%2525E5%2525B0%25258F%2525E9%252583%2525A8%2525E5%252588%252586%2525E5%252588%252597%2525E5%252595%25258F%2525E9%2525A1%25258C%252529%252Cw_1010%252Cx_90%252Cy_100%2Fg_south_west%252Cl_text%3Anotosansjp-medium.otf_37%3Anaoya_ito%252Cx_203%252Cy_98%2Fg_south_west%252Ch_90%252Cl_fetch%3AaHR0cHM6Ly9saDMuZ29vZ2xldXNlcmNvbnRlbnQuY29tL2EtL0FPaDE0R2lPejJjRnRRVXFpRTgtMUZWRGRRN2xrNFV2VXp1QXBIZTBwVnFxZUE9czk2LWM%3D%252Cr_max%252Cw_90%252Cx_87%252Cy_72%2Fog-base.png)