TakahiroNakamori

TakahiroNakamori

ナカモリタカヒロ

 
 

Gathering Children

問題

D – Gathering Children
プログラミング初級者から上級者まで楽しめる、競技プログラミングコンテストサイト「AtCoder」。オンラインで毎週開催プログラミングコンテストを開催しています。競技…

記録

解法

コード例

#include <bits/stdc++.h>
using namespace std;
#include <atcoder/all>
using namespace atcoder;
using ll = long long;
using P = pair<int, int>;
#define rep(i, n) for(int i = 0; i < (n); ++i)
// using mint = modint998244353;
// using mint = modint1000000007;
// const int mod = 1000000007;
// const ll INF = 1LL << 62;
// const int INF = 1001001001;

int main() {
  string S;
  cin >> S;

  int n = S.size();

  vector<vector<int>> dp(33, vector<int>(100100));

  rep(i, n) {
    if(S[i] == 'R') {
      dp[0][i] = i + 1;
    } else {
      dp[0][i] = i - 1;
    }
  }

  rep(p, 32) {
    rep(i, n) { dp[p + 1][i] = dp[p][dp[p][i]]; }
  }

  vector<int> ans(100100);
  rep(i, n) { ans[dp[32][i]]++; }

  rep(i, n) { cout << ans[i] << " "; }
  cout << endl;
  return 0;
}