CSES String Transform
// compile: make data
// run: ./data < data.in
#include <bits/stdc++.h>
using namespace std;
#pragma GCC optimize("O3,unroll-loops")
#pragma GCC target("avx2,bmi,bmi2,lzcnt,popcnt")
#ifdef LOCAL
#include <debug/cpglib/print.h>
#define debug(x...) _debug_print(0, #x, x);
#define Debug(x...) _debug_print(1, #x, x);
#define DEBUG(x...) _debug_print(2, #x, x);
std::ifstream terminal("/dev/tty");
#define PP cerr<<"\033[1;30mpause...\e[0m",terminal.ignore();
#else
#define debug(x...)
#define Debug(x...)
#define DEBUG(x...)
#define PP
#endif
template<typename...Args> void print_(Args...args){((cout<<args<<" "),...)<<endl;}
#define rep(i,a,b) for(int i=(a);i<(int)(b);++i)
#define sz(v) ((int)(v).size())
#define print(...) print_(__VA_ARGS__);
#define FIND(a, x) ((find(a.begin(),a.end(),(x))!=a.end())?1:0)
#define cmin(x,...) x=min({(x),__VA_ARGS__})
#define cmax(x,...) x=max({(x),__VA_ARGS__})
#define INTMAX (int)(9223372036854775807)
#define INF (int)(1152921504606846976)
#define NaN (int)(0x8b88e1d0595d51d1)
#define double long double
#define int long long
#define uint unsigned long long
#define endl "\n"
#define MAXN 200010
 
template<char SP> string bwt_inv(string bwt) {
    int n = bwt.length();
    string sorted = bwt;
    sort(sorted.begin(), sorted.end());
    vector<vector<int>> v(257);
    vector<int> ptr(257, 0), lshift(n);
    auto order = [](char c) -> int {
        return c == SP ? 0 : c + 1;
    };
    rep(i, 0, n) v[order(bwt[i])].push_back(i);
    rep(i, 0, n) lshift[i] = v[order(sorted[i])][ptr[order(sorted[i])]++];
    string orig = "";
    for (int i = find(bwt.begin(), bwt.end(), SP) - bwt.begin(); i != 0; i = lshift[i]) orig += sorted[i];
    return orig;
}
 
int32_t main() {
    ios::sync_with_stdio(false); cin.tie(nullptr); cout.tie(nullptr);
 
    string s; cin >> s;
    cout << bwt_inv<'#'>(s) << endl;
 
    return 0;
}

Comments

  1. 5 months ago
    2025-12-06 2:20:09

    Estatisticasbravobet is great for sports bettors. Check it out before you put any money down – estatisticasbravobet

  2. 5 months ago
    2025-12-19 13:35:01

    Looking for the zo88 apk download? Heard some buzz about it. Gonna grab it and see if it lives up to the hype. If you are like me, give it a go! zo88 apk download

  3. 4 months ago
    2025-12-29 6:03:06

    What’s up, gamers? Gave jilislotwin a spin. Got some decent wins, but nothing crazy. Anyone hit a jackpot on this site yet? Share your stories!

  4. 3 months ago
    2026-2-17 13:56:31

    Spincasinomx… I spent yesterday afternoon on this site. Excellent, I loved the selection of online games, so many to choose from, give it a try: spincasinomx

  5. 3 months ago
    2026-2-17 13:56:47

    Yo, CB33! Just checked it out. Not bad, not bad at all. Solid site. Worth a look. Check it out here cb33

  6. 3 months ago
    2026-2-17 13:57:03

    Jilibet777ph, Philippines represent! Had a blast playing. Good selection of games, and the payouts were decent. Highly recommend. Explore it yourself at jilibet777ph

  7. 1 month ago
    2026-3-30 13:01:46

    This BWT inversion implementation beautifully demonstrates how algorithmic efficiency transforms competitive programming solutions. The O(n) approach with proper character handling is exactly what separates good coders from great ones. For those seeking optimized experiences in digital platforms, check out kkkk ph app download apk – smooth performance matters everywhere.

  8. 3 weeks ago
    2026-4-13 6:23:59

    Thinking about trying the novibetapp. Seems like a convenient way to place bets directly from my phone. Any users have experience with this app? It couldn’t hurt to check it out! novibetapp

  9. 3 weeks ago
    2026-4-13 6:24:14

    Late night session on aw88casino last night. Pretty standard stuff, but the variety of games kept me entertained for a while. Worth a look if you’re searching for something new. See what you think of aw88casino.

  10. 3 weeks ago
    2026-4-13 6:24:30

    Downloaded the boss88apk the other day. Super convenient to have everything on my phone. Solid experience, really smooth on mobile. You should grab it from boss88apk and try it.

Send Comment Edit Comment


				
|´・ω・)ノ
ヾ(≧∇≦*)ゝ
(☆ω☆)
(╯‵□′)╯︵┴─┴
 ̄﹃ ̄
(/ω\)
∠( ᐛ 」∠)_
(๑•̀ㅁ•́ฅ)
→_→
୧(๑•̀⌄•́๑)૭
٩(ˊᗜˋ*)و
(ノ°ο°)ノ
(´இ皿இ`)
⌇●﹏●⌇
(ฅ´ω`ฅ)
(╯°A°)╯︵○○○
φ( ̄∇ ̄o)
ヾ(´・ ・`。)ノ"
( ง ᵒ̌皿ᵒ̌)ง⁼³₌₃
(ó﹏ò。)
Σ(っ °Д °;)っ
( ,,´・ω・)ノ"(´っω・`。)
╮(╯▽╰)╭
o(*////▽////*)q
>﹏<
( ๑´•ω•) "(ㆆᴗㆆ)
😂
😀
😅
😊
🙂
🙃
😌
😍
😘
😜
😝
😏
😒
🙄
😳
😡
😔
😫
😱
😭
💩
👻
🙌
🖕
👍
👫
👬
👭
🌚
🌝
🙈
💊
😶
🙏
🍦
🍉
😣
Source: github.com/k4yt3x/flowerhd
颜文字
Emoji
小恐龙
花!
Previous
Next