結果

問題 No.3134 二分探索木
ユーザー tnakao0123
提出日時 2025-05-03 17:53:05
言語 C++17
(gcc 13.3.0 + boost 1.87.0)
結果
TLE  
実行時間 -
コード長 1,206 bytes
コンパイル時間 628 ms
コンパイル使用メモリ 40,832 KB
実行使用メモリ 12,928 KB
最終ジャッジ日時 2025-05-03 17:53:11
合計ジャッジ時間 4,934 ms
ジャッジサーバーID
(参考情報)
judge1 / judge3
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
sample AC * 5
other AC * 8 TLE * 1 -- * 6
権限があれば一括ダウンロードができます
コンパイルメッセージ
main.cpp: In function ‘int main()’:
main.cpp:56:8: warning: ignoring return value of ‘int scanf(const char*, ...)’ declared with attribute ‘warn_unused_result’ [-Wunused-result]
   56 |   scanf("%d", &n);
      |   ~~~~~^~~~~~~~~~
main.cpp:57:36: warning: ignoring return value of ‘int scanf(const char*, ...)’ declared with attribute ‘warn_unused_result’ [-Wunused-result]
   57 |   for (int i = 0; i < n; i++) scanf("%d", as + i);
      |                               ~~~~~^~~~~~~~~~~~~~

ソースコード

diff #

/* -*- coding: utf-8 -*-
 *
 * 3134.cc:  No.3134 莠悟・謗「邏「譛ィ - yukicoder
 */

#include<cstdio>
#include<algorithm>

using namespace std;

/* constant */

const int MAX_N = 200000;

/* typedef */

struct Node {
  int a, b, c;
  Node *lpt, *rpt;
  Node(): a(), b(), c(), lpt(), rpt() {}
  Node(int _a): a(_a), b(), c(), lpt(), rpt() {}
  Node(int _a, int _b, int _c): a(_a), b(_b), c(_c), lpt(), rpt() {}
};

/* global variables */

int as[MAX_N];
Node *es[MAX_N];

/* subroutines */

void addnode(Node *u, int i) {
  for (;;) {
    u->c++;
    if (as[i] < u->a) {
      if (u->lpt == nullptr) {
	u->lpt = es[i] = new Node(as[i], u->b + 1, 0);
	break;
      }
      u = u->lpt;
    }
    else {
      if (u->rpt == nullptr) {
	u->rpt = es[i] = new Node(as[i], u->b + 1, 0);
	break;
      }
      u = u->rpt;
    }
  }
}

/* main */

int main() {
  int n;
  scanf("%d", &n);
  for (int i = 0; i < n; i++) scanf("%d", as + i);

  es[0] = new Node(as[0]);
  for (int i = 1; i < n; i++) addnode(es[0], i);

  for (int i = 0; i < n; i++)
    printf("%d%c", es[i]->b, (i + 1 < n) ? ' ' : '\n');
  for (int i = 0; i < n; i++)
    printf("%d%c", es[i]->c, (i + 1 < n) ? ' ' : '\n');
  
  return 0;
}
0