結果

問題 No.392 2分木をたどれ
ユーザー kyo1kyo1
提出日時 2020-11-24 13:07:19
言語 C++17
(gcc 12.3.0 + boost 1.83.0)
結果
AC  
実行時間 3 ms / 2,000 ms
コード長 962 bytes
コンパイル時間 2,244 ms
コンパイル使用メモリ 210,580 KB
実行使用メモリ 6,816 KB
最終ジャッジ日時 2024-07-23 18:27:32
合計ジャッジ時間 2,672 ms
ジャッジサーバーID
(参考情報)
judge5 / judge4
このコードへのチャレンジ
(要ログイン)

テストケース

テストケース表示
入力 結果 実行時間
実行使用メモリ
testcase_00 AC 2 ms
6,816 KB
testcase_01 AC 3 ms
6,812 KB
testcase_02 AC 3 ms
6,816 KB
権限があれば一括ダウンロードができます

ソースコード

diff #

#include <bits/stdc++.h>

using namespace std;

class Node {
 public:
  int parent;
  int n;
  char c;

  Node(int parent, int n, char c) : parent(parent), n(n), c(c) {}
};

int main() {
  ios::sync_with_stdio(false);
  cin.tie(nullptr);
  int M;
  cin >> M;
  vector<int> A(M);
  for (auto&& e : A) {
    cin >> e;
  }
  Node* root = new Node(0, 0, '$');
  vector<Node*> nodes;
  nodes.emplace_back(root);
  queue<Node*> que;
  que.push(root);
  int n = 0;
  while (n < 5000) {
    auto node = que.front();
    que.pop();
    Node* left = new Node(node->n, ++n, 'L');
    Node* right = new Node(node->n, ++n, 'R');
    nodes.emplace_back(left);
    nodes.emplace_back(right);
    que.push(left);
    que.push(right);
  }
  for (const auto& a : A) {
    string res = "";
    Node* cur = nodes[a];
    while (cur->n != 0) {
      res += cur->c;
      cur = nodes[cur->parent];
    }
    reverse(res.begin(), res.end());
    cout << res << '\n';
  }
  return 0;
}
0